DD4hep
1.30.0
Detector Description Toolkit for High Energy Physics
|
Concrete implementation of the Geant4 tracking action sequence. More...
#include <Geant4TrackingAction.h>
Public Member Functions | |
Geant4TrackingActionSequence (Geant4Context *context, const std::string &name) | |
Standard constructor. More... | |
virtual | ~Geant4TrackingActionSequence () |
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... | |
Geant4TrackingAction * | get (const std::string &name) const |
Get an action by name. More... | |
template<typename Q , typename T > | |
void | callUpFront (Q *p, void(T::*f)(const G4Track *), CallbackSequence::Location where=CallbackSequence::END) |
Register Pre-track action callback before anything else. More... | |
template<typename Q , typename T > | |
void | callAtBegin (Q *p, void(T::*f)(const G4Track *), CallbackSequence::Location where=CallbackSequence::END) |
Register Pre-track action callback. More... | |
template<typename Q , typename T > | |
void | callAtEnd (Q *p, void(T::*f)(const G4Track *), CallbackSequence::Location where=CallbackSequence::END) |
Register Post-track action callback. More... | |
template<typename Q , typename T > | |
void | callAtFinal (Q *p, void(T::*f)(const G4Track *), CallbackSequence::Location where=CallbackSequence::END) |
Register Post-track action callback. More... | |
void | adopt (Geant4TrackingAction *action) |
Add an actor responding to all callbacks. Sequence takes ownership. More... | |
virtual void | begin (const G4Track *track) |
Pre-tracking action callback. More... | |
virtual void | end (const G4Track *track) |
Post-tracking action 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 (Geant4TrackingActionSequence) | |
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_front |
Callback sequence for pre tracking action. More... | |
CallbackSequence | m_begin |
Callback sequence for pre tracking action. More... | |
CallbackSequence | m_end |
Callback sequence for post tracking action. More... | |
CallbackSequence | m_final |
Callback sequence for pre tracking action. More... | |
Actors< Geant4TrackingAction > | 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 tracking action sequence.
The sequence dispatches the callbacks for each tracking 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 114 of file Geant4TrackingAction.h.
Geant4TrackingActionSequence::Geant4TrackingActionSequence | ( | Geant4Context * | context, |
const std::string & | name | ||
) |
Standard constructor.
Definition at line 36 of file Geant4TrackingAction.cpp.
|
virtual |
Default destructor.
Definition at line 43 of file Geant4TrackingAction.cpp.
void Geant4TrackingActionSequence::adopt | ( | Geant4TrackingAction * | action | ) |
Add an actor responding to all callbacks. Sequence takes ownership.
Definition at line 70 of file Geant4TrackingAction.cpp.
|
virtual |
Pre-tracking action callback.
Pre-track action callback.
Definition at line 81 of file Geant4TrackingAction.cpp.
|
inline |
Register Pre-track action callback.
Definition at line 150 of file Geant4TrackingAction.h.
|
inline |
Register Post-track action callback.
Definition at line 156 of file Geant4TrackingAction.h.
|
inline |
Register Post-track action callback.
Definition at line 162 of file Geant4TrackingAction.h.
|
inline |
Register Pre-track action callback before anything else.
Definition at line 144 of file Geant4TrackingAction.h.
|
overridevirtual |
Set or update client for the use in a new thread fiber.
Reimplemented from dd4hep::sim::Geant4Action.
Definition at line 60 of file Geant4TrackingAction.cpp.
|
protected |
Define standard assignments and constructors.
|
virtual |
Post-tracking action callback.
Post-track action callback.
Definition at line 88 of file Geant4TrackingAction.cpp.
Geant4TrackingAction * Geant4TrackingActionSequence::get | ( | const std::string & | name | ) | const |
Get an action by name.
Definition at line 65 of file Geant4TrackingAction.cpp.
|
overridevirtual |
Set or update client context.
Reimplemented from dd4hep::sim::Geant4Action.
Definition at line 54 of file Geant4TrackingAction.cpp.
|
protected |
The list of action objects to be called.
Definition at line 125 of file Geant4TrackingAction.h.
|
protected |
Callback sequence for pre tracking action.
Definition at line 119 of file Geant4TrackingAction.h.
|
protected |
Callback sequence for post tracking action.
Definition at line 121 of file Geant4TrackingAction.h.
|
protected |
Callback sequence for pre tracking action.
Definition at line 123 of file Geant4TrackingAction.h.
|
protected |
Callback sequence for pre tracking action.
Definition at line 117 of file Geant4TrackingAction.h.