Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/global/management/include/G4StateManager.hh

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

  1 //
  2 // ********************************************************************
  3 // * License and Disclaimer                                           *
  4 // *                                                                  *
  5 // * The  Geant4 software  is  copyright of the Copyright Holders  of *
  6 // * the Geant4 Collaboration.  It is provided  under  the terms  and *
  7 // * conditions of the Geant4 Software License,  included in the file *
  8 // * LICENSE and available at  http://cern.ch/geant4/license .  These *
  9 // * include a list of copyright holders.                             *
 10 // *                                                                  *
 11 // * Neither the authors of this software system, nor their employing *
 12 // * institutes,nor the agencies providing financial support for this *
 13 // * work  make  any representation or  warranty, express or implied, *
 14 // * regarding  this  software system or assume any liability for its *
 15 // * use.  Please see the license in the file  LICENSE  and URL above *
 16 // * for the full disclaimer and the limitation of liability.         *
 17 // *                                                                  *
 18 // * This  code  implementation is the result of  the  scientific and *
 19 // * technical work of the GEANT4 collaboration.                      *
 20 // * By using,  copying,  modifying or  distributing the software (or *
 21 // * any work based  on the software)  you  agree  to acknowledge its *
 22 // * use  in  resulting  scientific  publications,  and indicate your *
 23 // * acceptance of all terms of the Geant4 Software license.          *
 24 // ********************************************************************
 25 //
 26 // G4StateManager
 27 //
 28 // Class description:
 29 //
 30 // Class responsible for handling and updating the running state
 31 // of the Geant4 application during its different phases.
 32 // The class is a singleton, it can be accessed via the public
 33 // method G4StateManager::GetStateManager().
 34 //
 35 // States of Geant4 are defined in G4ApplicationState.
 36 
 37 // Authors: G.Cosmo, M.Asai - November 1996
 38 // --------------------------------------------------------------------
 39 #ifndef G4StateManager_hh
 40 #define G4StateManager_hh 1
 41 
 42 #include "G4ApplicationState.hh"
 43 #include "G4String.hh"
 44 #include "G4Types.hh"
 45 #include "G4VExceptionHandler.hh"
 46 #include "G4VStateDependent.hh"
 47 #include <vector>
 48 
 49 class G4Run;
 50 class G4Event;
 51 
 52 class G4StateManager
 53 {
 54  public:
 55   static G4StateManager* GetStateManager();
 56   // The G4StateManager class is a singleton class and the pointer
 57   // to the only one existing object can be obtained by this static
 58   // method.
 59 
 60   ~G4StateManager();
 61 
 62   G4StateManager(const G4StateManager&) = delete;
 63   G4StateManager& operator=(const G4StateManager&) = delete;
 64   G4bool operator==(const G4StateManager&) const   = delete;
 65   G4bool operator!=(const G4StateManager&) const   = delete;
 66 
 67   const G4ApplicationState& GetCurrentState() const;
 68   // Returns the current state
 69   const G4ApplicationState& GetPreviousState() const;
 70   // Returns the previous state
 71   G4bool SetNewState(const G4ApplicationState& requestedState);
 72   // Set Geant4 to a new state.
 73   // In case the request is illegal, false will be returned
 74   // and the state of Geant4 will not be changed
 75   G4bool SetNewState(const G4ApplicationState& requestedState, const char* msg);
 76   // Set Geant4 to a new state.
 77   // In case the request is illegal, false will be returned
 78   // and the state of Geant4 will not be changed.
 79   // "msg" is the information associated to the state change
 80   G4bool RegisterDependent(G4VStateDependent* aDependent,
 81                            G4bool bottom = false);
 82   // Register a concrete class of G4VStateDependent.
 83   // Registered concrete classes will be notified via
 84   // G4VStateDependent::Notify() method when the state of Geant4 changes.
 85   // False will be returned if registration fails
 86   G4bool DeregisterDependent(G4VStateDependent* aDependent);
 87   // Remove the registration.
 88   // False will be returned if aDependent has not been registered
 89   G4VStateDependent* RemoveDependent(const G4VStateDependent* aDependent);
 90   // Remove the registration.
 91   // Removed pointer is returned
 92   G4String GetStateString(const G4ApplicationState& aState) const;
 93   // Utility method which returns a string of the state name
 94 
 95   void NotifyDeletion(const G4Event*);
 96   void NotifyDeletion(const G4Run*);
 97   // Notifying when an event or a run is deleted for the sake of avoiding
 98   // a state-dependent class from accessing to an obsolete event/run object.
 99 
100   inline void SetSuppressAbortion(G4int i);
101   inline G4int GetSuppressAbortion() const;
102   inline const char* GetMessage() const;
103   inline void SetExceptionHandler(G4VExceptionHandler* eh);
104   inline G4VExceptionHandler* GetExceptionHandler() const;
105   static void SetVerboseLevel(G4int val);
106 
107  private:
108   G4StateManager();
109 
110  private:
111   static G4ThreadLocal G4StateManager* theStateManager;
112   G4ApplicationState theCurrentState  = G4State_PreInit;
113   G4ApplicationState thePreviousState = G4State_PreInit;
114   std::vector<G4VStateDependent*> theDependentsList;
115   G4VStateDependent* theBottomDependent = nullptr;
116   G4int suppressAbortion                = 0;
117   const char* msgptr                    = nullptr;
118   G4VExceptionHandler* exceptionHandler = nullptr;
119   static G4int verboseLevel;
120 };
121 
122 #include "G4StateManager.icc"
123 
124 #endif
125