source: molecuilder/src/World.cpp@ 42918b

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

Fixed some problems with the usage of Boost::threads

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