source: molecuilder/src/World.cpp@ d2d8f5

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

Made all atoms register themselves with the world upon creation

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