The Gaudi Framework
v30r3 (a5ef0a68)
|
The Chrono & Stat Sservice: service implements the IChronoStatSvc interface and provides the basic chronometry and some statistical counts needed by all applications. More...
#include <src/ChronoStatSvc.h>
Public Types | |
typedef std::map< IChronoStatSvc::ChronoTag, ChronoEntity > | ChronoMap |
some useful typedefs More... | |
typedef std::map< IChronoStatSvc::StatTag, StatEntity > | StatMap |
Public Types inherited from extends< Service, IChronoStatSvc, IIncidentListener > | |
using | base_class = extends |
Typedef to this class. More... | |
using | extend_interfaces_base = extend_interfaces< Interfaces... > |
Typedef to the base of this class. More... | |
Public Types inherited from Service | |
using | Factory = Gaudi::PluginService::Factory< IService *(const std::string &, ISvcLocator *)> |
Public Types inherited from PropertyHolder< CommonMessaging< implements< IService, IProperty, IStateful > > > | |
using | PropertyHolderImpl = PropertyHolder< CommonMessaging< implements< IService, IProperty, IStateful > > > |
Typedef used to refer to this class from derived classes, as in. More... | |
Public Types inherited from CommonMessaging< implements< IService, IProperty, IStateful > > | |
using | base_class = CommonMessaging |
Public Types inherited from extend_interfaces< Interfaces... > | |
using | ext_iids = typename Gaudi::interface_list_cat< typename Interfaces::ext_iids... >::type |
take union of the ext_iids of all Interfaces... More... | |
Public Member Functions | |
StatusCode | initialize () override |
Implementation of IService::initialize() More... | |
StatusCode | finalize () override |
Implementation of IService::finalize() More... | |
ChronoEntity * | chronoStart (const IChronoStatSvc::ChronoTag &chronoTag) override |
Implementation of IChronoStatSvc::chronoStart. More... | |
const ChronoEntity * | chronoStop (const IChronoStatSvc::ChronoTag &chronoTag) override |
Implementation of IChronoStatSvc::chronoStop. More... | |
IChronoStatSvc::ChronoTime | chronoDelta (const IChronoStatSvc::ChronoTag &chronoTag, IChronoStatSvc::ChronoType theType) override |
Implementation of IchronoStatSvc::chronoDelta. More... | |
void | chronoPrint (const IChronoStatSvc::ChronoTag &chronoTag) override |
Implementation of IChronoStatSvc::chronoPrint. More... | |
ChronoStatus | chronoStatus (const IChronoStatSvc::ChronoTag &chronoTag) override |
Implementation of IChronoStatSvc::chronoStatus. More... | |
void | stat (const IChronoStatSvc::StatTag &statTag, const IChronoStatSvc::StatFlag &statFlag) override |
Implementation of IChronoStatSvc::stat add statistical information to the entity , tagged by its name. More... | |
void | statPrint (const IChronoStatSvc::ChronoTag &statTag) override |
prints (using message service) info about statistical entity, tagged by its name More... | |
const ChronoEntity * | chrono (const IChronoStatSvc::ChronoTag &t) const override |
extract the chrono entity for the given tag (name) More... | |
StatEntity * | stat (const IChronoStatSvc::StatTag &t) override |
extract the stat entity for the given tag (name) More... | |
ChronoStatSvc (const std::string &name, ISvcLocator *svcloc) | |
Default constructor. More... | |
void | merge (const ChronoStatSvc &css) |
Compound assignment operator. More... | |
void | handle (const Incident &incident) override |
Public Member Functions inherited from extends< Service, IChronoStatSvc, IIncidentListener > | |
void * | i_cast (const InterfaceID &tid) const override |
Implementation of IInterface::i_cast. More... | |
StatusCode | queryInterface (const InterfaceID &ti, void **pp) override |
Implementation of IInterface::queryInterface. More... | |
std::vector< std::string > | getInterfaceNames () const override |
Implementation of IInterface::getInterfaceNames. More... | |
Public Member Functions inherited from Service | |
const std::string & | name () const override |
Retrieve name of the service. More... | |
StatusCode | configure () override |
StatusCode | initialize () override |
StatusCode | start () override |
StatusCode | stop () override |
StatusCode | finalize () override |
StatusCode | terminate () override |
Gaudi::StateMachine::State | FSMState () const override |
Gaudi::StateMachine::State | targetFSMState () const override |
StatusCode | reinitialize () override |
StatusCode | restart () override |
StatusCode | sysInitialize () override |
Initialize Service. More... | |
StatusCode | sysStart () override |
Initialize Service. More... | |
StatusCode | sysStop () override |
Initialize Service. More... | |
StatusCode | sysFinalize () override |
Finalize Service. More... | |
StatusCode | sysReinitialize () override |
Re-initialize the Service. More... | |
StatusCode | sysRestart () override |
Re-initialize the Service. More... | |
Service (std::string name, ISvcLocator *svcloc) | |
Standard Constructor. More... | |
SmartIF< ISvcLocator > & | serviceLocator () const override |
Retrieve pointer to service locator. More... | |
StatusCode | setProperties () |
Method for setting declared properties to the values specified for the job. More... | |
template<class T > | |
StatusCode | service (const std::string &name, const T *&psvc, bool createIf=true) const |
Access a service by name, creating it if it doesn't already exist. More... | |
template<class T > | |
StatusCode | service (const std::string &name, T *&psvc, bool createIf=true) const |
template<typename IFace = IService> | |
SmartIF< IFace > | service (const std::string &name, bool createIf=true) const |
template<class T > | |
StatusCode | service (const std::string &svcType, const std::string &svcName, T *&psvc) const |
Access a service by name and type, creating it if it doesn't already exist. More... | |
template<class T > | |
StatusCode | declareTool (ToolHandle< T > &handle, std::string toolTypeAndName, bool createIf=true) |
Declare used tool. More... | |
SmartIF< IAuditorSvc > & | auditorSvc () const |
The standard auditor service.May not be invoked before sysInitialize() has been invoked. More... | |
Public Member Functions inherited from PropertyHolder< CommonMessaging< implements< IService, IProperty, IStateful > > > | |
PropertyHolder ()=default | |
Gaudi::Details::PropertyBase & | declareProperty (Gaudi::Details::PropertyBase &prop) |
Declare a property. More... | |
Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, TYPE &value, const std::string &doc="none") |
Helper to wrap a regular data member and use it as a regular property. More... | |
Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, Gaudi::Property< TYPE, VERIFIER, HANDLERS > &prop, const std::string &doc="none") |
Declare a PropertyBase instance setting name and documentation. More... | |
Gaudi::Details::PropertyBase * | declareRemoteProperty (const std::string &name, IProperty *rsvc, const std::string &rname="") |
Declare a remote property. More... | |
StatusCode | setProperty (const Gaudi::Details::PropertyBase &p) override |
set the property form another property More... | |
StatusCode | setProperty (const std::string &s) override |
set the property from the formatted string More... | |
StatusCode | setProperty (const std::string &n, const std::string &v) override |
set the property from name and the value More... | |
StatusCode | setProperty (const std::string &name, const TYPE &value) |
set the property form the value More... | |
StatusCode | getProperty (Gaudi::Details::PropertyBase *p) const override |
get the property More... | |
const Gaudi::Details::PropertyBase & | getProperty (const std::string &name) const override |
get the property by name More... | |
StatusCode | getProperty (const std::string &n, std::string &v) const override |
convert the property to the string More... | |
const std::vector< Gaudi::Details::PropertyBase * > & | getProperties () const override |
get all properties More... | |
bool | hasProperty (const std::string &name) const override |
Return true if we have a property with the given name. More... | |
PropertyHolder (const PropertyHolder &)=delete | |
PropertyHolder & | operator= (const PropertyHolder &)=delete |
Public Member Functions inherited from CommonMessaging< implements< IService, IProperty, IStateful > > | |
MSG::Level | msgLevel () const |
get the cached level (originally extracted from the embedded MsgStream) More... | |
bool | msgLevel (MSG::Level lvl) const |
get the output level from the embedded MsgStream More... | |
MSG::Level | outputLevel () const |
Backward compatibility function for getting the output level. More... | |
Public Member Functions inherited from CommonMessagingBase | |
virtual | ~CommonMessagingBase ()=default |
Virtual destructor. More... | |
const SmartIF< IMessageSvc > & | msgSvc () const |
The standard message service. More... | |
MsgStream & | msgStream () const |
Return an uninitialized MsgStream. More... | |
MsgStream & | msgStream (const MSG::Level level) const |
Predefined configurable message stream for the efficient printouts. More... | |
MsgStream & | always () const |
shortcut for the method msgStream(MSG::ALWAYS) More... | |
MsgStream & | fatal () const |
shortcut for the method msgStream(MSG::FATAL) More... | |
MsgStream & | err () const |
shortcut for the method msgStream(MSG::ERROR) More... | |
MsgStream & | error () const |
shortcut for the method msgStream(MSG::ERROR) More... | |
MsgStream & | warning () const |
shortcut for the method msgStream(MSG::WARNING) More... | |
MsgStream & | info () const |
shortcut for the method msgStream(MSG::INFO) More... | |
MsgStream & | debug () const |
shortcut for the method msgStream(MSG::DEBUG) More... | |
MsgStream & | verbose () const |
shortcut for the method msgStream(MSG::VERBOSE) More... | |
MsgStream & | msg () const |
shortcut for the method msgStream(MSG::INFO) More... | |
Protected Member Functions | |
void | printStats () |
Protected Member Functions inherited from Service | |
~Service () override | |
Standard Destructor. More... | |
int | outputLevel () const |
get the Service's output level More... | |
Protected Member Functions inherited from PropertyHolder< CommonMessaging< implements< IService, IProperty, IStateful > > > | |
Gaudi::Details::PropertyBase * | property (const std::string &name) const |
Protected Member Functions inherited from CommonMessaging< implements< IService, IProperty, IStateful > > | |
MSG::Level | setUpMessaging () const |
Set up local caches. More... | |
MSG::Level | resetMessaging () |
Reinitialize internal states. More... | |
void | updateMsgStreamOutputLevel (int level) |
Update the output level of the cached MsgStream. More... | |
Private Types | |
typedef std::map< ChronoTag, std::vector< IChronoSvc::ChronoTime > > | TimeMap |
Private Member Functions | |
ChronoStatSvc ()=delete | |
ChronoStatSvc (const ChronoStatSvc &)=delete | |
ChronoStatSvc & | operator= (const ChronoStatSvc &)=delete |
void | saveStats () |
dump the statistics into an ASCII file for offline processing More... | |
Additional Inherited Members | |
Protected Attributes inherited from Service | |
Gaudi::StateMachine::State | m_state = Gaudi::StateMachine::OFFLINE |
Service state. More... | |
Gaudi::StateMachine::State | m_targetState = Gaudi::StateMachine::OFFLINE |
Service state. More... | |
Gaudi::Property< int > | m_outputLevel {this, "OutputLevel", MSG::NIL, "output level"} |
Gaudi::Property< bool > | m_auditInit {this, "AuditServices", false, "[[deprecated]] unused"} |
Gaudi::Property< bool > | m_auditorInitialize {this, "AuditInitialize", false, "trigger auditor on initialize()"} |
Gaudi::Property< bool > | m_auditorStart {this, "AuditStart", false, "trigger auditor on start()"} |
Gaudi::Property< bool > | m_auditorStop {this, "AuditStop", false, "trigger auditor on stop()"} |
Gaudi::Property< bool > | m_auditorFinalize {this, "AuditFinalize", false, "trigger auditor on finalize()"} |
Gaudi::Property< bool > | m_auditorReinitialize {this, "AuditReinitialize", false, "trigger auditor on reinitialize()"} |
Gaudi::Property< bool > | m_auditorRestart {this, "AuditRestart", false, "trigger auditor on restart()"} |
SmartIF< IAuditorSvc > | m_pAuditorSvc |
Auditor Service. More... | |
The Chrono & Stat Sservice: service implements the IChronoStatSvc interface and provides the basic chronometry and some statistical counts needed by all applications.
Definition at line 33 of file ChronoStatSvc.h.
typedef std::map<IChronoStatSvc::ChronoTag, ChronoEntity> ChronoStatSvc::ChronoMap |
some useful typedefs
Definition at line 38 of file ChronoStatSvc.h.
typedef std::map<IChronoStatSvc::StatTag, StatEntity> ChronoStatSvc::StatMap |
Definition at line 39 of file ChronoStatSvc.h.
|
private |
Definition at line 170 of file ChronoStatSvc.h.
ChronoStatSvc::ChronoStatSvc | ( | const std::string & | name, |
ISvcLocator * | svcloc | ||
) |
Default constructor.
name | service instance name |
svcloc | pointer to servcie locator |
Definition at line 81 of file ChronoStatSvc.cpp.
|
privatedelete |
|
privatedelete |
|
override |
extract the chrono entity for the given tag (name)
t | chrono tag(name) |
Definition at line 388 of file ChronoStatSvc.cpp.
|
override |
Implementation of IchronoStatSvc::chronoDelta.
Definition at line 328 of file ChronoStatSvc.cpp.
|
override |
Implementation of IChronoStatSvc::chronoPrint.
Definition at line 336 of file ChronoStatSvc.cpp.
|
override |
Implementation of IChronoStatSvc::chronoStart.
Definition at line 310 of file ChronoStatSvc.cpp.
|
override |
Implementation of IChronoStatSvc::chronoStatus.
Definition at line 349 of file ChronoStatSvc.cpp.
|
override |
Implementation of IChronoStatSvc::chronoStop.
Definition at line 319 of file ChronoStatSvc.cpp.
|
override |
Implementation of IService::finalize()
stop its own chrono
Is the final chrono table to be printed?
decoration
CONTINUE
CONTINUE
stop chrono (if it is still in RUNNING status)
print to std::cout
print to MsgStream
decoration
CONTINUE
CONTINUE
stop chrono (if it is still in RUNNING status)
print to std::cout
print to MsgStream
decoration
CONTINUE
CONTINUE
stop chrono (if it is still in RUNNING status)
print to std::cout
print to MsgStream
clear the temporary container
the final decoration
Is the final stat table to be printed?
< finalize the base class
Definition at line 142 of file ChronoStatSvc.cpp.
|
override |
Definition at line 547 of file ChronoStatSvc.cpp.
|
override |
Implementation of IService::initialize()
start its own chrono
Definition at line 97 of file ChronoStatSvc.cpp.
void ChronoStatSvc::merge | ( | const ChronoStatSvc & | css | ) |
Compound assignment operator.
Definition at line 56 of file ChronoStatSvc.cpp.
|
privatedelete |
|
protected |
nothing to print?
CONTINUE
CONTINUE
decoration
Definition at line 477 of file ChronoStatSvc.cpp.
|
private |
dump the statistics into an ASCII file for offline processing
CONTINUE
CONTINUE
Definition at line 408 of file ChronoStatSvc.cpp.
|
override |
Implementation of IChronoStatSvc::stat add statistical information to the entity , tagged by its name.
Definition at line 356 of file ChronoStatSvc.cpp.
|
override |
extract the stat entity for the given tag (name)
t | stat tag(name) |
Definition at line 400 of file ChronoStatSvc.cpp.
|
override |
prints (using message service) info about statistical entity, tagged by its name
Definition at line 376 of file ChronoStatSvc.cpp.
|
private |
Definition at line 143 of file ChronoStatSvc.h.
|
private |
chrono part
Definition at line 132 of file ChronoStatSvc.h.
|
private |
Definition at line 146 of file ChronoStatSvc.h.
|
private |
level of info printing
Definition at line 134 of file ChronoStatSvc.h.
|
private |
Definition at line 141 of file ChronoStatSvc.h.
|
private |
Definition at line 161 of file ChronoStatSvc.h.
|
private |
Definition at line 145 of file ChronoStatSvc.h.
|
private |
Definition at line 154 of file ChronoStatSvc.h.
|
private |
Definition at line 172 of file ChronoStatSvc.h.
|
private |
Definition at line 168 of file ChronoStatSvc.h.
|
private |
Definition at line 171 of file ChronoStatSvc.h.
|
private |
Definition at line 149 of file ChronoStatSvc.h.
|
private |
Definition at line 148 of file ChronoStatSvc.h.
|
private |
Definition at line 147 of file ChronoStatSvc.h.
|
private |
Definition at line 152 of file ChronoStatSvc.h.
|
private |
stat part
Definition at line 137 of file ChronoStatSvc.h.
|
private |
Definition at line 155 of file ChronoStatSvc.h.
|
private |
level of info printing
Definition at line 139 of file ChronoStatSvc.h.
|
private |
Definition at line 157 of file ChronoStatSvc.h.
|
private |
Definition at line 150 of file ChronoStatSvc.h.
|
private |
Definition at line 165 of file ChronoStatSvc.h.