Ignore:
Timestamp:
Feb 16, 2010, 5:26:59 PM (16 years ago)
Author:
Tillmann Crueger <crueger@…>
Children:
b53a7e
Parents:
323177
Message:

Moved control of molecules and periode to World.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • molecuilder/src/World.cpp

    r323177 r120f8b  
    99
    1010#include "atom.hpp"
     11#include "molecule.hpp"
     12#include "periodentafel.hpp"
    1113#include "Descriptors/AtomDescriptor.hpp"
    1214
     
    1416
    1517/******************************* getter and setter ************************/
    16 periodentafel* World::getPeriode(){
     18periodentafel *&World::getPeriode(){
    1719  return periode;
    1820}
     
    2628}
    2729
     30int World::numAtoms(){
     31  return atoms.size();
     32}
     33
     34int World::numMolecules(){
     35  return molecules_deprecated->ListOfMolecules.size();
     36}
     37
     38molecule* World::createMolecule(){
     39  OBSERVE;
     40  molecule *mol = NULL;
     41  mol = new molecule(periode);
     42  molecules_deprecated->insert(mol);
     43  molecules.insert(mol);
     44  mol->signOn(this);
     45  return mol;
     46}
     47
     48
    2849/******************************* Singleton Stuff **************************/
    2950
     
    3556
    3657World::World() :
    37     dummyId(0)
     58    dummyId(0),
     59    periode(new periodentafel),
     60    molecules_deprecated(new MoleculeListClass)
    3861{}
    3962
    4063World::~World()
    41 {}
     64{
     65  delete periode;
     66}
    4267
    4368World* World::get(){
     
    5176
    5277void World::destroy(){
     78  // For legacy reasons all atoms have to be destroyed first, since unregistering would cause deadlocks otherwise
     79  theWorld->destroyLegacy();
     80  //WARNING: at this point we have a small race condition, when sombody now tries to access the world.
     81
    5382  // boost supports RAII-Style locking, so we don't need to unlock
    5483  boost::mutex::scoped_lock guard(worldLock);
     
    5887
    5988World* World::reset(){
     89  // For legacy reasons all atoms have to be destroyed first, since unregistering would cause deadlocks otherwise
     90  theWorld->destroyLegacy();
     91  //WARNING: at this point we have a small race condition, when sombody now tries to access the world.
     92
    6093  World* oldWorld = 0;
    6194  {
     
    81114/******************************* deprecated Legacy Stuff ***********************/
    82115
    83 MoleculeListClass *World::getMolecules() {
    84   return molecules;
     116MoleculeListClass *&World::getMolecules() {
     117  return molecules_deprecated;
    85118}
    86119
     
    91124}
    92125
     126void World::destroyLegacy(){
     127  //delete molecules_deprecated;
     128}
     129
    93130void World::unregisterAtom(atom *theAtom){
    94131  OBSERVE;
Note: See TracChangeset for help on using the changeset viewer.