The Gaudi Framework  master (37c0b60a)
IToolSvc Class Referenceabstract

#include <GaudiKernel/IToolSvc.h>

Inheritance diagram for IToolSvc:
Collaboration diagram for IToolSvc:

Classes

class  Observer
 allow call-backs when a tool is a created or retrieved More...
 

Public Types

typedef std::list< IAlgTool * > ListTools
 
- Public Types inherited from IInterface
enum  Status : StatusCode::code_t {
  Status::FAILURE = 0, Status::SUCCESS = 1, Status::NO_INTERFACE, Status::VERSMISMATCH,
  Status::LAST_ERROR
}
 Return status. More...
 
using iid = Gaudi::InterfaceId< IInterface, 0, 0 >
 Interface ID. More...
 
using ext_iids = Gaudi::interface_list< iid >
 Extra interfaces. More...
 

Public Member Functions

 DeclareInterfaceID (IToolSvc, 2, 1)
 InterfaceID. More...
 
virtual StatusCode retrieve (std::string_view type, const InterfaceID &iid, IAlgTool *&tool, const IInterface *parent=0, bool createIf=true)=0
 Retrieve tool with tool dependent part of the name automatically assigned. More...
 
virtual StatusCode retrieve (std::string_view type, std::string_view name, const InterfaceID &iid, IAlgTool *&tool, const IInterface *parent=0, bool createIf=true)=0
 Retrieve tool with tool dependent part of the name specified by the requester. More...
 
virtual std::vector< std::stringgetInstances (std::string_view toolType)=0
 Get the names of all instances of tools of a given type. More...
 
virtual std::vector< std::stringgetInstances () const =0
 Get the names all tool instances. More...
 
virtual std::vector< IAlgTool * > getTools () const =0
 Get pointers to all tool instances. More...
 
virtual StatusCode releaseTool (IAlgTool *tool)=0
 Release the tool. More...
 
template<class T >
StatusCode retrieveTool (std::string_view type, T *&tool, const IInterface *parent=nullptr, bool createIf=true)
 Retrieve specified tool sub-type with tool dependent part of the name automatically assigned. More...
 
template<class T >
StatusCode retrieveTool (std::string_view type, std::string_view name, T *&tool, const IInterface *parent=nullptr, bool createIf=true)
 Retrieve specified tool sub-type with tool dependent part of the name tool dependent part of the name specified by the requester. More...
 
virtual void registerObserver (Observer *obs)=0
 
- Public Member Functions inherited from IInterface
virtual void * i_cast (const InterfaceID &) const =0
 main cast function More...
 
virtual std::vector< std::stringgetInterfaceNames () const =0
 Returns a vector of strings containing the names of all the implemented interfaces. More...
 
virtual unsigned long addRef ()=0
 Increment the reference count of Interface instance. More...
 
virtual unsigned long release ()=0
 Release Interface instance. More...
 
virtual unsigned long refCount () const =0
 Current reference count. More...
 
virtual StatusCode queryInterface (const InterfaceID &ti, void **pp)=0
 Set the void** to the pointer to the requested interface of the instance. More...
 
virtual ~IInterface ()=default
 Virtual destructor. More...
 

Additional Inherited Members

- Static Public Member Functions inherited from IInterface
static const InterfaceIDinterfaceID ()
 Return an instance of InterfaceID identifying the interface. More...
 

Detailed Description

The interface implemented by the IToolSvc base class.

Author
G.Corti

Definition at line 29 of file IToolSvc.h.

Member Typedef Documentation

◆ ListTools

Definition at line 35 of file IToolSvc.h.

Member Function Documentation

◆ DeclareInterfaceID()

IToolSvc::DeclareInterfaceID ( IToolSvc  ,
,
 
)

◆ getInstances() [1/2]

virtual std::vector<std::string> IToolSvc::getInstances ( ) const
pure virtual

Get the names all tool instances.

◆ getInstances() [2/2]

virtual std::vector<std::string> IToolSvc::getInstances ( std::string_view  toolType)
pure virtual

Get the names of all instances of tools of a given type.

Parameters
toolTypetype of tool

◆ getTools()

virtual std::vector<IAlgTool*> IToolSvc::getTools ( ) const
pure virtual

Get pointers to all tool instances.

◆ registerObserver()

virtual void IToolSvc::registerObserver ( Observer obs)
pure virtual

◆ releaseTool()

virtual StatusCode IToolSvc::releaseTool ( IAlgTool tool)
pure virtual

Release the tool.

Parameters
toolto be released

◆ retrieve() [1/2]

virtual StatusCode IToolSvc::retrieve ( std::string_view  type,
const InterfaceID iid,
IAlgTool *&  tool,
const IInterface parent = 0,
bool  createIf = true 
)
pure virtual

Retrieve tool with tool dependent part of the name automatically assigned.

By default a tool will be created if it does not exist, unless otherwise specified. By default it will be a common tool unless a parent is specified. The parent of a common tool is automatically taken as the ToolSvc itself.

Parameters
typeAlgTool type name
iidthe unique interface identifier
toolreturned tool
parentconstant reference to the parent (def=none)
createIfcreation flag (def=create if not existing)

◆ retrieve() [2/2]

virtual StatusCode IToolSvc::retrieve ( std::string_view  type,
std::string_view  name,
const InterfaceID iid,
IAlgTool *&  tool,
const IInterface parent = 0,
bool  createIf = true 
)
pure virtual

Retrieve tool with tool dependent part of the name specified by the requester.

By default a tool will be created if it does not exist, unless otherwise specified. By default it will be a common tool unless a parent is specified. The parent of a common tool is automatically taken as the ToolSvc itself.

Parameters
typeAlgTool type name
namename to be assigned to tool dependent part of the name
iidthe unique interface identifier
toolreturned tool
parentconstant reference to parent (def=none)
createIfcreation flag (def=create if not existing)

◆ retrieveTool() [1/2]

template<class T >
StatusCode IToolSvc::retrieveTool ( std::string_view  type,
std::string_view  name,
T *&  tool,
const IInterface parent = nullptr,
bool  createIf = true 
)
inline

Retrieve specified tool sub-type with tool dependent part of the name tool dependent part of the name specified by the requester.

Internally it uses the corresponding IToolSvc::retrieve and does the dynamic casting.

IToolSvc* svc = ... ;
IMyTool* tool = 0 ;
StatusCode sc = svc->retrieveTool ( "MyToolType" ,
"MyToolName" , tool ) ;

For this example public tool of type 'MyToolType' will be retrieved from Tool Service (created on demand). The full name of the tool instance is set to be ToolSvc.MyToolName

IToolSvc* svc = ... ;
IAlgorithm* alg = ... ;
IMyTool* tool = 0 ;
StatusCode sc = svc->retrieveTool ( "MyToolType" ,
"MyToolName" , tool , alg ) ;

For this example the private tool of type 'MyToolType' will be retrieved from Tool Service (created on demand). The full name of the tool instance is set to be <AlgName>.MyToolName , where <AlgName> is a name of the algorithm.

If name is empty ("") it is assumed to be equal to the type

Parameters
typeAlgTool type name
namename to be assigned to tool dependent part of the name
toolreturned tool
parentconstant reference to parent (def=none)
createIfcreation flag (def=create if not existing)

Definition at line 196 of file IToolSvc.h.

197  {
198  return retrieve( type, name, T::interfaceID(), (IAlgTool*&)tool, parent, createIf );
199  }

◆ retrieveTool() [2/2]

template<class T >
StatusCode IToolSvc::retrieveTool ( std::string_view  type,
T *&  tool,
const IInterface parent = nullptr,
bool  createIf = true 
)
inline

Retrieve specified tool sub-type with tool dependent part of the name automatically assigned.

Internally it uses the corresponding IToolSvc::retrieve and does the dynamic casting.

IToolSvc* svc = ... ;
IMyTool* tool = 0 ;
StatusCode sc = svc->retrieveTool ( "MyToolType" , tool ) ;

For this example public tool of type 'MyToolType' will be retrieved from Tool Service (created on demand). The full name of the tool instance is set to be ToolSvc.MyToolType

IToolSvc* svc = ... ;
IAlgorithm* alg = ... ;
IMyTool* tool = 0 ;
StatusCode sc = svc->retrieveTool ( "MyToolType" , tool , alg ) ;

For this example the private tool of type 'MyToolType' will be retrieved from Tool Service (created on demand). The full name of the tool instance is set to be <AlgName>.MyToolType , where <AlgName> is a name of the algorithm.

IToolSvc* svc = ... ;
IMyTool* tool = 0 ;
StatusCode sc = svc->retrieveTool ( "MyToolType/MyToolName" , tool ) ;

For this example public tool of type 'MyToolType' will be retrieved from Tool Service (created on demand). The full name of the tool instance is set to be ToolSvc.MyToolName

IToolSvc* svc = ... ;
IAlgorithm* alg = ... ;
IMyTool* tool = 0 ;
StatusCode sc = svc ->
retrieveTool ( "MyToolType/MyToolName" , tool , alg ) ;

For this example the private tool of type 'MyToolType' will be retrieved from Tool Service (created on demand). The full name of the tool instance is set to be <AlgName>.MyToolName , where <AlgName> is a name of the algorithm.

Parameters
toolreturned tool
parentconstant reference to parent (def=none)
createIfcreation flag (def=create if not existing)

Definition at line 148 of file IToolSvc.h.

148  {
149  return retrieve( type, T::interfaceID(), (IAlgTool*&)tool, parent, createIf );
150  }

The documentation for this class was generated from the following file:
IAlgTool
Definition: IAlgTool.h:33
IMyTool
Definition: IMyTool.h:22
ManySmallAlgs.alg
alg
Definition: ManySmallAlgs.py:81
bug_34121.tool
tool
Definition: bug_34121.py:18
StatusCode
Definition: StatusCode.h:65
IAlgorithm
Definition: IAlgorithm.h:38
IToolSvc::retrieve
virtual StatusCode retrieve(std::string_view type, const InterfaceID &iid, IAlgTool *&tool, const IInterface *parent=0, bool createIf=true)=0
Retrieve tool with tool dependent part of the name automatically assigned.
IToolSvc::retrieveTool
StatusCode retrieveTool(std::string_view type, T *&tool, const IInterface *parent=nullptr, bool createIf=true)
Retrieve specified tool sub-type with tool dependent part of the name automatically assigned.
Definition: IToolSvc.h:148
gaudirun.type
type
Definition: gaudirun.py:160
ConditionsStallTest.name
name
Definition: ConditionsStallTest.py:77
IToolSvc
Definition: IToolSvc.h:29