|  | The Gaudi Framework
    v36r9 (fd2bdac3)
    | 
#include </builds/gaudi/Gaudi/GaudiCoreSvc/src/ApplicationMgr/ToolSvc.h>


| Public Member Functions | |
| ~ToolSvc () override | |
| Destructor.  More... | |
| StatusCode | finalize () override | 
| Finalize the service.  More... | |
| StatusCode | start () override | 
| StatusCode | stop () override | 
| StatusCode | retrieve (std::string_view type, const InterfaceID &iid, IAlgTool *&tool, const IInterface *parent, bool createIf) override | 
| Retrieve tool, create it by default as common tool if it does not already exist.  More... | |
| StatusCode | retrieve (std::string_view tooltype, std::string_view toolname, const InterfaceID &iid, IAlgTool *&tool, const IInterface *parent, bool createIf) override | 
| Retrieve tool, create it by default as common tool if it does not already exist.  More... | |
| std::vector< std::string > | getInstances (std::string_view toolType) override | 
| Get names of all tool instances of a given type.  More... | |
| std::vector< std::string > | getInstances () const override | 
| Get names of all tool instances.  More... | |
| std::vector< IAlgTool * > | getTools () const override | 
| Get pointers to all tool instances.  More... | |
| StatusCode | releaseTool (IAlgTool *tool) override | 
| Release tool.  More... | |
| StatusCode | create (const std::string &type, const IInterface *parent, IAlgTool *&tool) | 
| Create Tool standard way with automatically assigned name.  More... | |
| StatusCode | create (const std::string &type, const std::string &name, const IInterface *parent, IAlgTool *&tool) | 
| Create Tool standard way with specified name.  More... | |
| bool | existsTool (std::string_view toolname) const | 
| Check if the tool instance exists.  More... | |
| std::string | nameTool (std::string_view nameByUser, const IInterface *parent) | 
| Get Tool full name by combining nameByUser and "parent" part.  More... | |
| void | registerObserver (IToolSvc::Observer *obs) override | 
|  Public Member Functions inherited from extends< Service, IToolSvc > | |
| 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... | |
| 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 > | |
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, ToolHandle< T > &hndl, const std::string &doc="none") | 
| template<class T > | |
| StatusCode | declareTool (ToolHandle< T > &handle, bool createIf=true) | 
| template<class T > | |
| StatusCode | declareTool (ToolHandle< T > &handle, std::string toolTypeAndName, bool createIf=true) | 
| Declare used tool.  More... | |
| template<class T > | |
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, ToolHandleArray< T > &hndlArr, const std::string &doc="none") | 
| template<class T > | |
| void | addToolsArray (ToolHandleArray< T > &hndlArr) | 
| const std::vector< IAlgTool * > & | tools () const | 
| 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 std::string &name, const Gaudi::Details::PropertyBase &p) override | 
| set the property from another property with a different name  More... | |
| StatusCode | setProperty (const std::string &s) override | 
| set the property from the formatted string  More... | |
| StatusCode | setProperty (const Gaudi::Details::PropertyBase &p) | 
| Set the property from a property.  More... | |
| virtual StatusCode | setProperty (const std::string &name, const Gaudi::Details::PropertyBase &p)=0 | 
| Set the property from a property with a different name.  More... | |
| virtual StatusCode | setProperty (const std::string &s)=0 | 
| Set the property by string.  More... | |
| StatusCode | setProperty (const std::string &name, const char *v) | 
| Special case for string literals.  More... | |
| StatusCode | setProperty (const std::string &name, const std::string &v) | 
| Special case for std::string.  More... | |
| StatusCode | setProperty (const std::string &name, const TYPE &value) | 
| set the property form the value  More... | |
| StatusCode | setPropertyRepr (const std::string &n, const std::string &r) override | 
| set the property from name and value string representation  More... | |
| StatusCode | getProperty (Gaudi::Details::PropertyBase *p) const override | 
| get the property  More... | |
| const Gaudi::Details::PropertyBase & | getProperty (std::string_view name) const override | 
| get the property by name  More... | |
| StatusCode | getProperty (std::string_view 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 (std::string_view name) const override | 
| Return true if we have a property with the given name.  More... | |
| Gaudi::Details::PropertyBase * | property (std::string_view name) const | 
| \fixme property and bindPropertiesTo should be protected  More... | |
| void | bindPropertiesTo (Gaudi::Interfaces::IOptionsSvc &optsSvc) | 
| 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... | |
| Private Types | |
| typedef std::recursive_mutex | CallMutex | 
| Private Member Functions | |
| unsigned long | totalToolRefCount () const | 
| The total number of refCounts on all tools in the instancesTools list.  More... | |
| unsigned long | minimumToolRefCount () const | 
| The minimum number of refCounts of all tools.  More... | |
| StatusCode | finalizeTool (IAlgTool *itool) const | 
| Finalize the given tool, with exception handling.  More... | |
| Private Attributes | |
| std::vector< IAlgTool * > | m_instancesTools | 
| Common Tools.  More... | |
| IHistorySvc * | m_pHistorySvc = nullptr | 
| Pointer to HistorySvc.  More... | |
| std::vector< IToolSvc::Observer * > | m_observers | 
| CallMutex | m_mut | 
| Additional Inherited Members | |
|  Public Types inherited from extends< Service, IToolSvc > | |
| 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... | |
|  Protected Member Functions inherited from Service | |
| std::vector< IAlgTool * > & | tools () | 
| ~Service () override | |
| Standard Destructor More... | |
| int | outputLevel () const | 
| get the Service'soutput level  More... | |
|  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... | |
|  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" } | 
| flag indicating whether ToolHandle tools have been added to m_tools  More... | |
| 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()" } | 
| Gaudi::Property< bool > | m_autoRetrieveTools | 
| Gaudi::Property< bool > | m_checkToolDeps | 
| SmartIF< IAuditorSvc > | m_pAuditorSvc | 
| Auditor Service More... | |
This service manages tools. Tools can be common, in which case a single instance can be shared by different algorithms, or private in which case it is necessary to specify the parent when requesting it. The parent of a tool can be an algortihm or a Service The environment of a tool is set by using that of the parent. A common tool is considered to belong to the ToolSvc itself.
| 
 | private | 
| 
 | override | 
| StatusCode ToolSvc::create | ( | const std::string & | type, | 
| const IInterface * | parent, | ||
| IAlgTool *& | tool | ||
| ) | 
Create Tool standard way with automatically assigned name.
Definition at line 366 of file ToolSvc.cpp.
| StatusCode ToolSvc::create | ( | const std::string & | tooltype, | 
| const std::string & | toolname, | ||
| const IInterface * | parent, | ||
| IAlgTool *& | tool | ||
| ) | 
Create Tool standard way with specified name.
Now able to handle clones.
The test of tool existence is performed according to three criteria: name, type and parent. If a tool is private, i.e. the parent is not the tool Svc, and it exist but the parent is not the specified one, a clone is handed over. No clones of public tools are allowed since they would be undistinguishable.
invoke create callbacks...
Definition at line 425 of file ToolSvc.cpp.
| bool ToolSvc::existsTool | ( | std::string_view | toolname | ) | const | 
| 
 | override | 
Finalize the service.
Algorithm: 2 passes. First pass:
Inner loop: full loop over all left-over tools
Definition at line 63 of file ToolSvc.cpp.
| 
 | private | 
Finalize the given tool, with exception handling.
Definition at line 578 of file ToolSvc.cpp.
| 
 | override | 
Get names of all tool instances.
Definition at line 319 of file ToolSvc.cpp.
| 
 | override | 
Get names of all tool instances of a given type.
Definition at line 307 of file ToolSvc.cpp.
| 
 | override | 
| 
 | private | 
| std::string ToolSvc::nameTool | ( | std::string_view | nameByUser, | 
| const IInterface * | parent | ||
| ) | 
Get Tool full name by combining nameByUser and "parent" part.
Definition at line 549 of file ToolSvc.cpp.
| 
 | override | 
Definition at line 624 of file ToolSvc.cpp.
| 
 | override | 
Release tool.
Definition at line 336 of file ToolSvc.cpp.
| 
 | override | 
Retrieve tool, create it by default as common tool if it does not already exist.
invoke retrieve callbacks...
Definition at line 243 of file ToolSvc.cpp.
| 
 | override | 
Retrieve tool, create it by default as common tool if it does not already exist.
Definition at line 219 of file ToolSvc.cpp.
| 
 | override | 
Definition at line 638 of file ToolSvc.cpp.
| 
 | override | 
Definition at line 662 of file ToolSvc.cpp.
| 
 | private | 
The total number of refCounts on all tools in the instancesTools list.
Definition at line 608 of file ToolSvc.cpp.
| 
 | private | 
| 
 | private | 
| 
 | private | 
Pointer to HistorySvc.