source: molecuilder/src/World.cpp@ 86b917

Last change on this file since 86b917 was 86b917, checked in by Tillmann Crueger <crueger@…>, 16 years ago

Added descriptors that allow multiple kinds of access to atoms

  • Property mode set to 100644
File size: 2.1 KB
Line 
1/*
2 * World.cpp
3 *
4 * Created on: Feb 3, 2010
5 * Author: crueger
6 */
7
8#include "World.hpp"
9
10#include "atom.hpp"
11#include "Descriptors/AtomDescriptor.hpp"
12
13using namespace std;
14
15/******************************* getter and setter ************************/
16periodentafel* World::getPeriode(){
17 return periode;
18}
19
20atom* World::getAtom(AtomDescriptor &descriptor){
21 return descriptor.find();
22}
23
24vector<atom*> World::getAllAtoms(AtomDescriptor &descriptor){
25 return descriptor.findAll();
26}
27
28/******************************* Singleton Stuff **************************/
29
30// TODO: Hide boost-thread using Autotools stuff when no threads are used
31World* World::theWorld = 0;
32boost::mutex World::worldLock;
33
34
35
36World::World()
37{}
38
39World::~World()
40{}
41
42World* World::get(){
43 // boost supports RAII-Style locking, so we don't need to unlock
44 boost::mutex::scoped_lock guard(worldLock);
45 if(!theWorld) {
46 theWorld = new World();
47 }
48 return theWorld;
49}
50
51void World::destroy(){
52 // boost supports RAII-Style locking, so we don't need to unlock
53 boost::mutex::scoped_lock guard(worldLock);
54 delete theWorld;
55 theWorld = 0;
56}
57
58World* World::reset(){
59 World* oldWorld = 0;
60 {
61 // boost supports RAII-Style locking, so we don't need to unlock
62 boost::mutex::scoped_lock guard(worldLock);
63
64 oldWorld = theWorld;
65 theWorld = new World();
66 // oldworld does not need protection any more,
67 // since we should have the only reference
68
69 // worldLock handles access to the pointer,
70 // not to the object
71 } // scope-end releases the lock
72
73 // we have to let all the observers know that the
74 // oldWorld was destroyed. oldWorld calls subjectKilled
75 // upon destruction. Every Observer getting that signal
76 // should see that it gets the updated new world
77 delete oldWorld;
78}
79
80/******************************* deprecated Legacy Stuff ***********************/
81
82MoleculeListClass *World::getMolecules() {
83 return molecules;
84}
85
86// some legacy stuff to let the World know about items created outside
87void World::registerAtom(atom *theAtom){
88 OBSERVE;
89 atoms[theAtom->getId()] = theAtom;
90}
91
92void World::unregisterAtom(atom *theAtom){
93 OBSERVE;
94 atoms.erase(theAtom->getId());
95}
Note: See TracBrowser for help on using the repository browser.