Geant4 Cross Reference |
1 // 1 // 2 // ******************************************* 2 // ******************************************************************** 3 // * License and Disclaimer 3 // * License and Disclaimer * 4 // * 4 // * * 5 // * The Geant4 software is copyright of th 5 // * The Geant4 software is copyright of the Copyright Holders of * 6 // * the Geant4 Collaboration. It is provided 6 // * the Geant4 Collaboration. It is provided under the terms and * 7 // * conditions of the Geant4 Software License 7 // * conditions of the Geant4 Software License, included in the file * 8 // * LICENSE and available at http://cern.ch/ 8 // * LICENSE and available at http://cern.ch/geant4/license . These * 9 // * include a list of copyright holders. 9 // * include a list of copyright holders. * 10 // * 10 // * * 11 // * Neither the authors of this software syst 11 // * Neither the authors of this software system, nor their employing * 12 // * institutes,nor the agencies providing fin 12 // * institutes,nor the agencies providing financial support for this * 13 // * work make any representation or warran 13 // * work make any representation or warranty, express or implied, * 14 // * regarding this software system or assum 14 // * regarding this software system or assume any liability for its * 15 // * use. Please see the license in the file 15 // * use. Please see the license in the file LICENSE and URL above * 16 // * for the full disclaimer and the limitatio 16 // * for the full disclaimer and the limitation of liability. * 17 // * 17 // * * 18 // * This code implementation is the result 18 // * This code implementation is the result of the scientific and * 19 // * technical work of the GEANT4 collaboratio 19 // * technical work of the GEANT4 collaboration. * 20 // * By using, copying, modifying or distri 20 // * By using, copying, modifying or distributing the software (or * 21 // * any work based on the software) you ag 21 // * any work based on the software) you agree to acknowledge its * 22 // * use in resulting scientific publicati 22 // * use in resulting scientific publications, and indicate your * 23 // * acceptance of all terms of the Geant4 Sof 23 // * acceptance of all terms of the Geant4 Software license. * 24 // ******************************************* 24 // ******************************************************************** 25 // 25 // 26 // G4ApplicationState << 27 // 26 // 28 // Description: << 27 // $Id: G4ApplicationState.hh,v 1.4 2006/06/29 19:01:20 gunter Exp $ >> 28 // GEANT4 tag $Name: geant4-09-00 $ >> 29 // >> 30 >> 31 #ifndef G4APPLICATIONSTATE_H >> 32 #define G4APPLICATIONSTATE_H 1 >> 33 >> 34 // Class Description: 29 // 35 // 30 // Specifies the state of the G4 application 36 // Specifies the state of the G4 application 31 // 37 // 32 // States: 38 // States: 33 // G4State_PreInit 39 // G4State_PreInit 34 // At the very beginning of the Application << 40 // At the very begining of the Application. G4StateManager starts 35 // with this state. G4Initializer changes t 41 // with this state. G4Initializer changes this state to Init when 36 // G4Initializer::Initialize() method start 42 // G4Initializer::Initialize() method starts. At the moment of 37 // the state change of PreInit->Init, no ma 43 // the state change of PreInit->Init, no material, geometrical, 38 // particle or physics process has been ini 44 // particle or physics process has been initialized. 39 // G4State_Init 45 // G4State_Init 40 // During the G4Initializer::Initialize() m 46 // During the G4Initializer::Initialize() method. G4Initializer 41 // changes this state to Idle when all init 47 // changes this state to Idle when all initialization procedures 42 // are successfully Done. 48 // are successfully Done. 43 // G4State_Idle 49 // G4State_Idle 44 // Ready to start "BeamOn". G4RunManager ch 50 // Ready to start "BeamOn". G4RunManager changes this state to 45 // GeomClosed when G4RunManager::BeamOn() m 51 // GeomClosed when G4RunManager::BeamOn() method starts and 46 // G4GeometryManager::CloseGeometry() is Do 52 // G4GeometryManager::CloseGeometry() is Done. At the end of 47 // BeamOn() method, G4RunManager will reset 53 // BeamOn() method, G4RunManager will reset the application state 48 // to Idle after G4GeometryManager::OpenGeo 54 // to Idle after G4GeometryManager::OpenGeometry() is Done. 49 // G4State_GeomClosed 55 // G4State_GeomClosed 50 // Geant4 is in this state between G4Geomet << 56 // G4 is in this state between G4GeometryManager::CloseGeometry() 51 // and G4GeometryManager::OpenGeometry(), b << 57 // and G4GeometryManager::OpenGeometry(), but no event is in 52 // progress. At the begining of each event 58 // progress. At the begining of each event (construction of a 53 // G4Event object and primary particle gene 59 // G4Event object and primary particle generation), G4RunManager 54 // changes this state to EventProc and rese 60 // changes this state to EventProc and resets to GeomClosed state 55 // when G4EventManager::ProcessOneEvent() i 61 // when G4EventManager::ProcessOneEvent() is over. 56 // G4State_EventProc 62 // G4State_EventProc 57 // Processing an event. 63 // Processing an event. 58 // G4State_Quit 64 // G4State_Quit 59 // Geant4 is in this state when the destruc << 65 // G4 is in this state when the destructor of G4RunManager is invoked. 60 // G4State_Abort 66 // G4State_Abort 61 // Geant4 is in this state when G4Exception << 67 // G4 is in this state when G4Exception is invoked. 62 // << 68 // 63 // 69 // 64 // PreInit 70 // PreInit 65 // | 71 // | 66 // v 72 // v 67 // Init 73 // Init 68 // | 74 // | 69 // v 75 // v 70 // Idle ------> Quit 76 // Idle ------> Quit 71 // |^ 77 // |^ 72 // v| 78 // v| 73 // GeomClosed (at each run) 79 // GeomClosed (at each run) 74 // |^ 80 // |^ 75 // v| 81 // v| 76 // EventProc (at each event) 82 // EventProc (at each event) 77 // 83 // 78 // ------------------------------------------- << 79 #ifndef G4APPLICATIONSTATE_HH << 80 #define G4APPLICATIONSTATE_HH 1 << 81 84 82 enum G4ApplicationState << 85 enum G4ApplicationState 83 { << 86 {G4State_PreInit, G4State_Init, G4State_Idle, G4State_GeomClosed, 84 G4State_PreInit, << 87 G4State_EventProc, G4State_Quit, G4State_Abort}; 85 G4State_Init, << 88 86 G4State_Idle, << 87 G4State_GeomClosed, << 88 G4State_EventProc, << 89 G4State_Quit, << 90 G4State_Abort << 91 }; << 92 #endif 89 #endif >> 90 93 91