Changes in src/World.hpp [31af19:6e97e5]
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
src/World.hpp
r31af19 r6e97e5 16 16 #include <boost/shared_ptr.hpp> 17 17 18 #include "defs.hpp" 18 #include "types.hpp" 19 #include "Descriptors/SelectiveIterator.hpp" 19 20 #include "Patterns/Observer.hpp" 20 21 #include "Patterns/Cacheable.hpp" 22 #include "Patterns/Singleton.hpp" 23 21 24 22 25 // forward declarations … … 33 36 class AtomsCalculation; 34 37 35 class World : public Observable 38 39 40 class World : public Singleton<World>, public Observable 36 41 { 42 43 // Make access to constructor and destructor possible from inside the singleton 44 friend class Singleton<World>; 45 37 46 // necessary for coupling with descriptors 38 47 friend class AtomDescriptor_impl; … … 45 54 template<typename> friend class AtomsCalculation; 46 55 public: 56 57 // Types for Atom and Molecule structures 47 58 typedef std::map<atomId_t,atom*> AtomSet; 48 59 typedef std::map<moleculeId_t,molecule*> MoleculeSet; … … 150 161 151 162 // Atoms 152 153 class AtomIterator : 154 public std::iterator<std::iterator_traits<AtomSet::iterator>::difference_type, 155 std::iterator_traits<AtomSet::iterator>::value_type, 156 std::iterator_traits<AtomSet::iterator>::pointer, 157 std::iterator_traits<AtomSet::iterator>::reference> 158 { 159 public: 160 161 typedef AtomSet::iterator _Iter; 162 typedef _Iter::value_type value_type; 163 typedef _Iter::difference_type difference_type; 164 typedef _Iter::pointer pointer; 165 typedef _Iter::reference reference; 166 typedef _Iter::iterator_category iterator_category; 167 168 169 AtomIterator(); 170 AtomIterator(AtomDescriptor, World*); 171 AtomIterator(const AtomIterator&); 172 AtomIterator& operator=(const AtomIterator&); 173 AtomIterator& operator++(); // prefix 174 AtomIterator operator++(int); // postfix with dummy parameter 175 bool operator==(const AtomIterator&); 176 bool operator==(const AtomSet::iterator&); 177 bool operator!=(const AtomIterator&); 178 bool operator!=(const AtomSet::iterator&); 179 atom* operator*(); 180 181 int getCount(); 182 protected: 183 void advanceState(); 184 AtomSet::iterator state; 185 boost::shared_ptr<AtomDescriptor_impl> descr; 186 int index; 187 188 World* world; 189 }; 163 typedef SelectiveIterator<atom*,AtomSet,AtomDescriptor> AtomIterator; 190 164 191 165 /** … … 201 175 * used for internal purposes, like AtomProcesses and AtomCalculations. 202 176 */ 203 Atom Set::iterator atomEnd();177 AtomIterator atomEnd(); 204 178 205 179 // Molecules 206 180 207 class MoleculeIterator : 208 public std::iterator<std::iterator_traits<MoleculeSet::iterator>::difference_type, 209 std::iterator_traits<MoleculeSet::iterator>::value_type, 210 std::iterator_traits<MoleculeSet::iterator>::pointer, 211 std::iterator_traits<MoleculeSet::iterator>::reference> 212 { 213 public: 214 215 typedef MoleculeSet::iterator _Iter; 216 typedef _Iter::value_type value_type; 217 typedef _Iter::difference_type difference_type; 218 typedef _Iter::pointer pointer; 219 typedef _Iter::reference reference; 220 typedef _Iter::iterator_category iterator_category; 221 222 MoleculeIterator(); 223 MoleculeIterator(MoleculeDescriptor, World*); 224 MoleculeIterator(const MoleculeIterator&); 225 MoleculeIterator& operator=(const MoleculeIterator&); 226 MoleculeIterator& operator++(); // prefix 227 MoleculeIterator operator++(int); // postfix with dummy parameter 228 bool operator==(const MoleculeIterator&); 229 bool operator==(const MoleculeSet::iterator&); 230 bool operator!=(const MoleculeIterator&); 231 bool operator!=(const MoleculeSet::iterator&); 232 molecule* operator*(); 233 234 int getCount(); 235 protected: 236 void advanceState(); 237 MoleculeSet::iterator state; 238 boost::shared_ptr<MoleculeDescriptor_impl> descr; 239 int index; 240 241 World* world; 242 }; 181 typedef SelectiveIterator<molecule*,MoleculeSet,MoleculeDescriptor> MoleculeIterator; 243 182 244 183 /** … … 254 193 * used for internal purposes, like MoleculeProcesses and MoleculeCalculations. 255 194 */ 256 Molecule Set::iterator moleculeEnd();195 MoleculeIterator moleculeEnd(); 257 196 258 197 … … 267 206 268 207 periodentafel *periode; 208 public: 269 209 AtomSet atoms; 210 private: 270 211 std::set<atomId_t> atomIdPool; //<!stores the pool for all available AtomIds below currAtomId 271 212 atomId_t currAtomId; //!< stores the next available Id for atoms 272 213 MoleculeSet molecules; 273 214 moleculeId_t currMoleculeId; 274 275 276 /***** singleton Stuff *****/277 public:278 279 /**280 * get the currently active instance of the World.281 */282 static World* get();283 284 /**285 * destroy the currently active instance of the World.286 */287 static void destroy();288 289 /**290 * destroy the currently active instance of the World and immidiately291 * create a new one. Use this to reset while somebody is still Observing292 * the world and should reset the observed instance. All observers will be293 * sent the subjectKille() message from the old world.294 */295 static World* reset();296 297 215 private: 298 216 /** … … 307 225 */ 308 226 virtual ~World(); 309 310 static World *theWorld;311 // this mutex only saves the singleton pattern...312 // use other mutexes to protect internal data as well313 // this mutex handles access to the pointer, not to the object!!!314 static boost::mutex worldLock;315 227 316 228 /*****
Note:
See TracChangeset
for help on using the changeset viewer.