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