00001 /* 00002 Sheep - A Rigid Body Dynamics Engine 00003 Copyright (C) 2001-2004 Francois Beaune 00004 Contact: http://toxicengine.sourceforge.net/ 00005 00006 This file is part of Sheep. 00007 00008 Sheep is free software; you can redistribute it and/or modify 00009 it under the terms of the GNU General Public License as published by 00010 the Free Software Foundation; either version 2 of the License, or 00011 (at your option) any later version. 00012 00013 Sheep is distributed in the hope that it will be useful, 00014 but WITHOUT ANY WARRANTY; without even the implied warranty of 00015 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00016 GNU General Public License for more details. 00017 00018 You should have received a copy of the GNU General Public License 00019 along with Sheep; if not, write to the Free Software 00020 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 00021 */ 00022 00023 #include "subspace.h" 00024 #include "world.h" 00025 00026 #include <cassert> 00027 00028 using namespace sheep; 00029 00030 void World::Insert(Subspace *subspace) { 00031 assert(subspace); 00032 00033 subspace->AttachTo(this); 00034 00035 m_subspaces.push_back(subspace); 00036 } 00037 00038 void World::Remove(Subspace *subspace) { 00039 assert(subspace); 00040 00041 m_subspaces.remove(subspace); 00042 } 00043 00044 void World::StepBy(Real step) { 00045 const Real EPSILON = 1e-6; 00046 00047 //!\todo Is this really necessary? (see Subspace::StepBy) 00048 assert(step > EPSILON); 00049 00050 Real step_end = m_time + step; 00051 00052 for(subspace_list::iterator i = m_subspaces.begin(); i != m_subspaces.end(); i++) { 00053 Subspace *subspace = *i; 00054 00055 subspace->Step(m_time, step_end); 00056 } 00057 00058 m_time = step_end; 00059 }
1.3.6