Changeset cd032d for src/World.hpp


Ignore:
Timestamp:
Mar 11, 2010, 2:46:41 PM (16 years ago)
Author:
Tillmann Crueger <crueger@…>
Branches:
Action_Thermostats, Add_AtomRandomPerturbation, Add_FitFragmentPartialChargesAction, Add_RotateAroundBondAction, Add_SelectAtomByNameAction, Added_ParseSaveFragmentResults, AddingActions_SaveParseParticleParameters, Adding_Graph_to_ChangeBondActions, Adding_MD_integration_tests, Adding_ParticleName_to_Atom, Adding_StructOpt_integration_tests, AtomFragments, Automaking_mpqc_open, AutomationFragmentation_failures, Candidate_v1.5.4, Candidate_v1.6.0, Candidate_v1.6.1, Candidate_v1.7.0, ChangeBugEmailaddress, ChangingTestPorts, ChemicalSpaceEvaluator, CombiningParticlePotentialParsing, Combining_Subpackages, Debian_Package_split, Debian_package_split_molecuildergui_only, Disabling_MemDebug, Docu_Python_wait, EmpiricalPotential_contain_HomologyGraph, EmpiricalPotential_contain_HomologyGraph_documentation, Enable_parallel_make_install, Enhance_userguide, Enhanced_StructuralOptimization, Enhanced_StructuralOptimization_continued, Example_ManyWaysToTranslateAtom, Exclude_Hydrogens_annealWithBondGraph, FitPartialCharges_GlobalError, Fix_BoundInBox_CenterInBox_MoleculeActions, Fix_ChargeSampling_PBC, Fix_ChronosMutex, Fix_FitPartialCharges, Fix_FitPotential_needs_atomicnumbers, Fix_ForceAnnealing, Fix_IndependentFragmentGrids, Fix_ParseParticles, Fix_ParseParticles_split_forward_backward_Actions, Fix_PopActions, Fix_QtFragmentList_sorted_selection, Fix_Restrictedkeyset_FragmentMolecule, Fix_StatusMsg, Fix_StepWorldTime_single_argument, Fix_Verbose_Codepatterns, Fix_fitting_potentials, Fixes, ForceAnnealing_goodresults, ForceAnnealing_oldresults, ForceAnnealing_tocheck, ForceAnnealing_with_BondGraph, ForceAnnealing_with_BondGraph_continued, ForceAnnealing_with_BondGraph_continued_betteresults, ForceAnnealing_with_BondGraph_contraction-expansion, FragmentAction_writes_AtomFragments, FragmentMolecule_checks_bonddegrees, GeometryObjects, Gui_Fixes, Gui_displays_atomic_force_velocity, ImplicitCharges, IndependentFragmentGrids, IndependentFragmentGrids_IndividualZeroInstances, IndependentFragmentGrids_IntegrationTest, IndependentFragmentGrids_Sole_NN_Calculation, JobMarket_RobustOnKillsSegFaults, JobMarket_StableWorkerPool, JobMarket_unresolvable_hostname_fix, MoreRobust_FragmentAutomation, ODR_violation_mpqc_open, PartialCharges_OrthogonalSummation, PdbParser_setsAtomName, PythonUI_with_named_parameters, QtGui_reactivate_TimeChanged_changes, Recreated_GuiChecks, Rewrite_FitPartialCharges, RotateToPrincipalAxisSystem_UndoRedo, SaturateAtoms_findBestMatching, SaturateAtoms_singleDegree, StoppableMakroAction, Subpackage_CodePatterns, Subpackage_JobMarket, Subpackage_LinearAlgebra, Subpackage_levmar, Subpackage_mpqc_open, Subpackage_vmg, Switchable_LogView, ThirdParty_MPQC_rebuilt_buildsystem, TrajectoryDependenant_MaxOrder, TremoloParser_IncreasedPrecision, TremoloParser_MultipleTimesteps, TremoloParser_setsAtomName, Ubuntu_1604_changes, stable
Children:
68d781
Parents:
a77c96 (diff), ed58ad (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent.
Message:

Merge branch 'StructureRefactoring' into QT4Refactoring

Conflicts:

molecuilder/src/builder.cpp
molecuilder/src/defs.hpp

File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/World.hpp

    ra77c96 rcd032d  
    1919#include "Patterns/Observer.hpp"
    2020#include "Patterns/Cacheable.hpp"
     21#include "Patterns/Singleton.hpp"
     22
    2123
    2224// forward declarations
     
    3335class AtomsCalculation;
    3436
    35 class World : public Observable
     37
     38
     39class World : public Singleton<World>, public Observable
    3640{
     41
     42// Make access to constructor and destructor possible from inside the singleton
     43friend class Singleton<World>;
     44
    3745// necessary for coupling with descriptors
    3846friend class AtomDescriptor_impl;
     
    4553template<typename> friend class AtomsCalculation;
    4654public:
     55
     56  // Types for Atom and Molecule structures
    4757  typedef std::map<atomId_t,atom*> AtomSet;
    4858  typedef std::map<moleculeId_t,molecule*> MoleculeSet;
     
    151161  // Atoms
    152162
    153   class AtomIterator {
     163  class AtomIterator :
     164    public std::iterator<std::iterator_traits<AtomSet::iterator>::difference_type,
     165                         std::iterator_traits<AtomSet::iterator>::value_type,
     166                         std::iterator_traits<AtomSet::iterator>::pointer,
     167                         std::iterator_traits<AtomSet::iterator>::reference>
     168  {
    154169  public:
     170
     171    typedef AtomSet::iterator _Iter;
     172    typedef _Iter::value_type value_type;
     173    typedef _Iter::difference_type difference_type;
     174    typedef _Iter::pointer pointer;
     175    typedef _Iter::reference reference;
     176    typedef _Iter::iterator_category iterator_category;
     177
     178
    155179    AtomIterator();
    156180    AtomIterator(AtomDescriptor, World*);
     
    191215  // Molecules
    192216
    193   class MoleculeIterator {
     217  class MoleculeIterator :
     218    public std::iterator<std::iterator_traits<MoleculeSet::iterator>::difference_type,
     219                         std::iterator_traits<MoleculeSet::iterator>::value_type,
     220                         std::iterator_traits<MoleculeSet::iterator>::pointer,
     221                         std::iterator_traits<MoleculeSet::iterator>::reference>
     222  {
    194223  public:
     224
     225    typedef MoleculeSet::iterator _Iter;
     226    typedef _Iter::value_type value_type;
     227    typedef _Iter::difference_type difference_type;
     228    typedef _Iter::pointer pointer;
     229    typedef _Iter::reference reference;
     230    typedef _Iter::iterator_category iterator_category;
     231
    195232    MoleculeIterator();
    196233    MoleculeIterator(MoleculeDescriptor, World*);
     
    245282  MoleculeSet molecules;
    246283  moleculeId_t currMoleculeId;
    247 
    248 
    249   /***** singleton Stuff *****/
    250 public:
    251 
    252   /**
    253    * get the currently active instance of the World.
    254    */
    255   static World* get();
    256 
    257   /**
    258    * destroy the currently active instance of the World.
    259    */
    260   static void destroy();
    261 
    262   /**
    263    * destroy the currently active instance of the World and immidiately
    264    * create a new one. Use this to reset while somebody is still Observing
    265    * the world and should reset the observed instance. All observers will be
    266    * sent the subjectKille() message from the old world.
    267    */
    268   static World* reset();
    269 
    270284private:
    271285  /**
     
    280294   */
    281295  virtual ~World();
    282 
    283   static World *theWorld;
    284   // this mutex only saves the singleton pattern...
    285   // use other mutexes to protect internal data as well
    286   // this mutex handles access to the pointer, not to the object!!!
    287   static boost::mutex worldLock;
    288296
    289297  /*****
Note: See TracChangeset for help on using the changeset viewer.