DD4hep
1.30.0
Detector Description Toolkit for High Energy Physics
|
Concrete implementation of the Geant4 stepping action sequence. More...
#include <Geant4SteppingAction.h>
Public Member Functions | |
Geant4SteppingActionSequence (Geant4Context *context, const std::string &name) | |
Standard constructor. More... | |
virtual | ~Geant4SteppingActionSequence () |
Default destructor. More... | |
virtual void | updateContext (Geant4Context *ctxt) override |
Set or update client context. More... | |
virtual void | configureFiber (Geant4Context *thread_context) override |
Set or update client for the use in a new thread fiber. More... | |
Geant4SteppingAction * | get (const std::string &name) const |
Get an action by name. More... | |
template<typename Q , typename T > | |
void | call (Q *p, void(T::*f)(const G4Step *, G4SteppingManager *)) |
Register stepping action callback. Types Q and T must be polymorph! More... | |
void | adopt (Geant4SteppingAction *action) |
Add an actor responding to all callbacks. Sequence takes ownership. More... | |
virtual void | operator() (const G4Step *step, G4SteppingManager *mgr) |
User stepping callback. More... | |
Public Member Functions inherited from dd4hep::sim::Geant4Action | |
Geant4Action (Geant4Context *context, const std::string &nam) | |
Standard constructor. More... | |
long | addRef () |
Increase reference count. More... | |
long | release () |
Decrease reference count. Implicit destruction. More... | |
Geant4Context * | context () const |
Access the context. More... | |
const std::string & | name () const |
Access name of the action. More... | |
const char * | c_name () const |
Access name of the action. More... | |
void | setName (const std::string &new_name) |
Set the object name. More... | |
PropertyManager & | properties () |
Access to the properties of the object. More... | |
PrintLevel | outputLevel () const |
Access the output level. More... | |
PrintLevel | setOutputLevel (PrintLevel new_level) |
Set the output level; returns previous value. More... | |
Geant4UIMessenger * | control () const |
Access to the UI messenger. More... | |
virtual void | enableUI () |
Enable and install UI messenger. More... | |
template<typename T > | |
Geant4Action & | declareProperty (const std::string &nam, T &val) |
Declare property. More... | |
template<typename T > | |
Geant4Action & | declareProperty (const char *nam, T &val) |
Declare property. More... | |
bool | hasProperty (const std::string &name) const |
Check property for existence. More... | |
Property & | property (const std::string &name) |
Access single property. More... | |
virtual void | installMessengers () |
Install property control messenger if wanted. More... | |
virtual void | installCommandMessenger () |
Install command control messenger if wanted. More... | |
virtual void | installPropertyMessenger () |
Install property control messenger if wanted. More... | |
void | print (const char *fmt,...) const |
Support for messages with variable output level using output level. More... | |
void | printM1 (const char *fmt,...) const |
Support for messages with variable output level using output level-1. More... | |
void | printM2 (const char *fmt,...) const |
Support for messages with variable output level using output level-2. More... | |
void | printP1 (const char *fmt,...) const |
Support for messages with variable output level using output level+1. More... | |
void | printP2 (const char *fmt,...) const |
Support for messages with variable output level using output level+2. More... | |
void | always (const char *fmt,...) const |
Support of always printed messages. More... | |
void | debug (const char *fmt,...) const |
Support of debug messages. More... | |
void | info (const char *fmt,...) const |
Support of info messages. More... | |
void | warning (const char *fmt,...) const |
Support of warning messages. More... | |
void | error (const char *fmt,...) const |
Support of error messages. More... | |
bool | return_error (bool return_value, const char *fmt,...) const |
Action to support error messages. More... | |
void | fatal (const char *fmt,...) const |
Support of fatal messages. Throws exception. More... | |
void | except (const char *fmt,...) const |
Support of exceptions: Print fatal message and throw runtime_error. More... | |
void | abortRun (const std::string &exception, const char *fmt,...) const |
Abort Geant4 Run by throwing a G4Exception with type RunMustBeAborted. More... | |
Geant4RunActionSequence & | runAction () const |
Access to the main run action sequence from the kernel object. More... | |
Geant4EventActionSequence & | eventAction () const |
Access to the main event action sequence from the kernel object. More... | |
Geant4SteppingActionSequence & | steppingAction () const |
Access to the main stepping action sequence from the kernel object. More... | |
Geant4TrackingActionSequence & | trackingAction () const |
Access to the main tracking action sequence from the kernel object. More... | |
Geant4StackingActionSequence & | stackingAction () const |
Access to the main stacking action sequence from the kernel object. More... | |
Geant4GeneratorActionSequence & | generatorAction () const |
Access to the main generator action sequence from the kernel object. More... | |
Protected Member Functions | |
DDG4_DEFINE_ACTION_CONSTRUCTORS (Geant4SteppingActionSequence) | |
Define standard assignments and constructors. More... | |
Protected Member Functions inherited from dd4hep::sim::Geant4Action | |
DDG4_DEFINE_ACTION_CONSTRUCTORS (Geant4Action) | |
Define standard assignments and constructors. More... | |
virtual | ~Geant4Action () |
Default destructor. More... | |
Protected Attributes | |
CallbackSequence | m_calls |
Callback sequence for user stepping action calls. More... | |
Actors< Geant4SteppingAction > | m_actors |
The list of action objects to be called. More... | |
Protected Attributes inherited from dd4hep::sim::Geant4Action | |
Geant4Context * | m_context { nullptr } |
Reference to the Geant4 context. More... | |
Geant4UIMessenger * | m_control { nullptr } |
Control directory of this action. More... | |
int | m_outputLevel { 3 } |
Default property: Output level. More... | |
bool | m_needsControl { false } |
Default property: Flag to create control instance. More... | |
std::string | m_name { } |
Action name. More... | |
PropertyManager | m_properties { } |
Property pool. More... | |
long | m_refCount { 1 } |
Reference count. Initial value: 1. More... | |
Concrete implementation of the Geant4 stepping action sequence.
The sequence dispatches the callbacks for each stepping action to all registered Geant4SteppingAction members and all registered callbacks.
Note Multi-Threading issue: Neither callbacks not the action list is protected against multiple threads calling the Geant4 callbacks! These must be protected in the user actions themselves.
Definition at line 104 of file Geant4SteppingAction.h.
Geant4SteppingActionSequence::Geant4SteppingActionSequence | ( | Geant4Context * | context, |
const std::string & | name | ||
) |
Standard constructor.
Definition at line 82 of file Geant4SteppingAction.cpp.
|
virtual |
Default destructor.
Definition at line 89 of file Geant4SteppingAction.cpp.
void Geant4SteppingActionSequence::adopt | ( | Geant4SteppingAction * | action | ) |
Add an actor responding to all callbacks. Sequence takes ownership.
Definition at line 119 of file Geant4SteppingAction.cpp.
|
inline |
Register stepping action callback. Types Q and T must be polymorph!
Definition at line 127 of file Geant4SteppingAction.h.
|
overridevirtual |
Set or update client for the use in a new thread fiber.
Reimplemented from dd4hep::sim::Geant4Action.
Definition at line 97 of file Geant4SteppingAction.cpp.
|
protected |
Define standard assignments and constructors.
Geant4SteppingAction * Geant4SteppingActionSequence::get | ( | const std::string & | name | ) | const |
Get an action by name.
Definition at line 108 of file Geant4SteppingAction.cpp.
|
virtual |
User stepping callback.
Pre-track action callback.
Definition at line 113 of file Geant4SteppingAction.cpp.
|
overridevirtual |
Set or update client context.
Reimplemented from dd4hep::sim::Geant4Action.
Definition at line 102 of file Geant4SteppingAction.cpp.
|
protected |
The list of action objects to be called.
Definition at line 109 of file Geant4SteppingAction.h.
|
protected |
Callback sequence for user stepping action calls.
Definition at line 107 of file Geant4SteppingAction.h.