source: molecuilder/src/World.cpp@ 2e8296

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

Started development of World Class

  • Property mode set to 100644
File size: 1.5 KB
Line 
1/*
2 * World.cpp
3 *
4 * Created on: Feb 3, 2010
5 * Author: crueger
6 */
7
8#include "World.hpp"
9
10/******************************* getter and setter ************************/
11periodentafel* World::getPeriode(){
12 return periode;
13}
14
15/******************************* Singleton Stuff **************************/
16
17World* World::theWorld = 0;
18
19
20World::World()
21{}
22
23World::~World()
24{}
25
26World* World::get(){
27 // boost supports RAII-Style locking, so we don't need to unlock
28 boost::mutex::scoped_lock guard(worldLock);
29 if(!theWorld) {
30 theWorld = new World();
31 }
32 return theWorld;
33}
34
35void World::destroy(){
36 // boost supports RAII-Style locking, so we don't need to unlock
37 boost::mutex::scoped_lock guard(worldLock);
38 delete theWorld;
39 theWorld = 0;
40}
41
42World* World::reset(){
43 World* oldWorld = 0;
44 {
45 // boost supports RAII-Style locking, so we don't need to unlock
46 boost::mutex::scoped_lock guard(worldLock);
47
48 oldWorld = theWorld;
49 theWorld = new World();
50 // oldworld does not need protection any more,
51 // since we should have the only reference
52
53 // worldLock handles access to the pointer,
54 // not to the object
55 } // scope-end releases the lock
56
57 // we have to let all the observers know that the
58 // oldWorld was destroyed. oldWorld calls subjectKilled
59 // upon destruction. Every Observer getting that signal
60 // should see that it gets the updated new world
61 delete oldWorld;
62}
63
64/******************************* deprecated Legacy Stuff ***********************/
65
66MoleculeListClass *World::getMolecules() {
67 return molecules;
68}
Note: See TracBrowser for help on using the repository browser.