The Gaudi Framework  v30r3 (a5ef0a68)
ISvcLocator Class Referenceabstract

The ISvcLocator is the interface implemented by the Service Factory in the Application Manager to locate services in the framework. More...

#include <GaudiKernel/ISvcLocator.h>

Inheritance diagram for ISvcLocator:
Collaboration diagram for ISvcLocator:

Public Member Functions

 DeclareInterfaceID (ISvcLocator, 3, 0)
 InterfaceID. More...
 
virtual StatusCode getService (const Gaudi::Utils::TypeNameString &typeName, IService *&svc, const bool createIf=true)
 Get a reference to the service given a service name. More...
 
virtual StatusCode getService (const Gaudi::Utils::TypeNameString &typeName, const InterfaceID &iid, IInterface *&pinterface)
 Get a specific interface pointer given a service name and interface id. More...
 
virtual const std::list< IService * > & getServices () const =0
 Get a reference to a service and create it if it does not exists. More...
 
virtual bool existsService (const std::string &name) const =0
 Check the existence of a service given a service name. More...
 
template<class T >
StatusCode service (const Gaudi::Utils::TypeNameString &name, T *&svc, bool createIf=true)
 Templated method to access a service by name. More...
 
template<class T >
StatusCode service (const std::string &type, const std::string &name, T *&svc, bool createIf=true)
 Templated method to access a service by type and name. More...
 
virtual SmartIF< IService > & service (const Gaudi::Utils::TypeNameString &typeName, const bool createIf=true)=0
 Returns a smart pointer to a service. More...
 
template<typename T >
SmartIF< T > service (const Gaudi::Utils::TypeNameString &typeName, const bool createIf=true)
 Returns a smart pointer to the requested interface of a service. More...
 
template<typename IFace >
SmartIF< IFace > as ()
 
- 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

- 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...
 
- Static Public Member Functions inherited from IInterface
static const InterfaceIDinterfaceID ()
 Return an instance of InterfaceID identifying the interface. More...
 

Detailed Description

The ISvcLocator is the interface implemented by the Service Factory in the Application Manager to locate services in the framework.

Clients use this interface to locate references to interfaces of services existing in the application. This operation needs to be done before the service can be used by the client. Typically "locating the services" is done at the initialization phase of the clients.

Author
Pere Mato

Definition at line 25 of file ISvcLocator.h.

Member Function Documentation

template<typename IFace >
SmartIF<IFace> ISvcLocator::as ( )
inline

Definition at line 109 of file ISvcLocator.h.

110  {
111  return SmartIF<IFace>{this};
112  }
Small smart pointer class with automatic reference counting for IInterface.
Definition: IConverter.h:15
ISvcLocator::DeclareInterfaceID ( ISvcLocator  ,
,
 
)
virtual bool ISvcLocator::existsService ( const std::string name) const
pure virtual

Check the existence of a service given a service name.

virtual StatusCode ISvcLocator::getService ( const Gaudi::Utils::TypeNameString typeName,
IService *&  svc,
const bool  createIf = true 
)
inlinevirtual

Get a reference to the service given a service name.

Parameters
nameService name
svcReturned service pointer

Definition at line 36 of file ISvcLocator.h.

38  {
39  SmartIF<IService>& s = service( typeName, createIf );
40  svc = s.get();
41  if ( svc ) {
42  svc->addRef(); // Needed to maintain the correct reference counting.
43  return StatusCode::SUCCESS;
44  }
45  return StatusCode::FAILURE;
46  }
constexpr static const auto FAILURE
Definition: StatusCode.h:88
TYPE * get() const
Get interface pointer.
Definition: SmartIF.h:82
StatusCode service(const Gaudi::Utils::TypeNameString &name, T *&svc, bool createIf=true)
Templated method to access a service by name.
Definition: ISvcLocator.h:79
constexpr static const auto SUCCESS
Definition: StatusCode.h:87
string s
Definition: gaudirun.py:253
virtual StatusCode ISvcLocator::getService ( const Gaudi::Utils::TypeNameString typeName,
const InterfaceID iid,
IInterface *&  pinterface 
)
inlinevirtual

Get a specific interface pointer given a service name and interface id.

Parameters
nameService name
iidInterface ID
pinterfaceReturned pointer to the requested interface

Definition at line 53 of file ISvcLocator.h.

55  {
56  auto svc = service( typeName, false );
57  return svc ? svc->queryInterface( iid, (void**)&pinterface ) : StatusCode::FAILURE;
58  }
constexpr static const auto FAILURE
Definition: StatusCode.h:88
StatusCode service(const Gaudi::Utils::TypeNameString &name, T *&svc, bool createIf=true)
Templated method to access a service by name.
Definition: ISvcLocator.h:79
virtual const std::list<IService*>& ISvcLocator::getServices ( ) const
pure virtual

Get a reference to a service and create it if it does not exists.

Parameters
nameService name
svcReturned service pointer
createIfflag to control the creationReturn the list of Services
template<class T >
StatusCode ISvcLocator::service ( const Gaudi::Utils::TypeNameString name,
T *&  svc,
bool  createIf = true 
)
inline

Templated method to access a service by name.

Definition at line 79 of file ISvcLocator.h.

80  {
81  if ( createIf ) {
82  IService* s;
83  StatusCode sc = getService( name, s, true );
84  if ( !sc.isSuccess() ) return sc; // Must check if initialization was OK!
85  }
86  return getService( name, T::interfaceID(), (IInterface*&)svc );
87  }
bool isSuccess() const
Definition: StatusCode.h:287
General service interface definition.
Definition: IService.h:18
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
Definition of the basic interface.
Definition: IInterface.h:277
virtual StatusCode getService(const Gaudi::Utils::TypeNameString &typeName, IService *&svc, const bool createIf=true)
Get a reference to the service given a service name.
Definition: ISvcLocator.h:36
string s
Definition: gaudirun.py:253
template<class T >
StatusCode ISvcLocator::service ( const std::string type,
const std::string name,
T *&  svc,
bool  createIf = true 
)
inline

Templated method to access a service by type and name.

Definition at line 91 of file ISvcLocator.h.

92  {
93  return service( type + "/" + name, svc, createIf );
94  }
StatusCode service(const Gaudi::Utils::TypeNameString &name, T *&svc, bool createIf=true)
Templated method to access a service by name.
Definition: ISvcLocator.h:79
virtual SmartIF<IService>& ISvcLocator::service ( const Gaudi::Utils::TypeNameString typeName,
const bool  createIf = true 
)
pure virtual

Returns a smart pointer to a service.

template<typename T >
SmartIF<T> ISvcLocator::service ( const Gaudi::Utils::TypeNameString typeName,
const bool  createIf = true 
)
inline

Returns a smart pointer to the requested interface of a service.

Definition at line 102 of file ISvcLocator.h.

103  {
104  return SmartIF<T>{service( typeName, createIf )};
105  }
Small smart pointer class with automatic reference counting for IInterface.
Definition: IConverter.h:15
StatusCode service(const Gaudi::Utils::TypeNameString &name, T *&svc, bool createIf=true)
Templated method to access a service by name.
Definition: ISvcLocator.h:79

The documentation for this class was generated from the following file: