The Gaudi Framework  v30r3 (a5ef0a68)
Gaudi::BootSvcLocator Class Reference

A dual-stage boostrap mechanism is used to ensure an orderly startup of the ApplicationMgr. More...

Inheritance diagram for Gaudi::BootSvcLocator:
Collaboration diagram for Gaudi::BootSvcLocator:

Public Member Functions

StatusCode getService (const Gaudi::Utils::TypeNameString &typeName, const InterfaceID &iid, IInterface *&pinterface) override
 
StatusCode getService (const Gaudi::Utils::TypeNameString &typeName, IService *&svc, const bool createIf=true) override
 
const std::list< IService * > & getServices () const override
 
bool existsService (const std::string &name) const override
 
SmartIF< IService > & service (const Gaudi::Utils::TypeNameString &typeName, const bool createIf=true) override
 Returns a smart pointer to a service. More...
 
- Public Member Functions inherited from implements< ISvcLocator >
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::stringgetInterfaceNames () const override
 Implementation of IInterface::getInterfaceNames. More...
 
 implements ()=default
 Default constructor. More...
 
 implements (const implements &)
 Copy constructor (zero the reference count) More...
 
implementsoperator= (const implements &)
 Assignment operator (do not touch the reference count). More...
 
unsigned long addRef () override
 Reference Interface instance. More...
 
unsigned long release () override
 Release Interface instance. More...
 
unsigned long refCount () const override
 Current reference count. More...
 

Additional Inherited Members

- Public Types inherited from implements< ISvcLocator >
using base_class = implements< Interfaces... >
 Typedef to this class. More...
 
using extend_interfaces_base = extend_interfaces< Interfaces... >
 Typedef to the base of this class. More...
 
using iids = typename extend_interfaces_base::ext_iids
 
- 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 Attributes inherited from implements< ISvcLocator >
std::atomic_ulong m_refCount
 Reference counter. More...
 

Detailed Description

A dual-stage boostrap mechanism is used to ensure an orderly startup of the ApplicationMgr.

If this function is called before the singleton ApplicationMgr instance exists, a BootstrapAppMgr singleton instance is created. This responds to any subsequent requests for services by returning StatusCode::FAILURE, unless the ApplicationMgr singleton instance has been created in the interim. In this case, the BootstrapAppMgr forwards the request to the ApplicationMgr instance. The motivation for this is to handle static object instances where the constructor attempts to locate services and would otherwise instantiate the ApplicationMgr instance in an unorderly manner. This logic requires that the ApplicationMgr instance is created explicitly.

Definition at line 40 of file Bootstrap.cpp.

Member Function Documentation

bool Gaudi::BootSvcLocator::existsService ( const std::string name) const
override

Definition at line 221 of file Bootstrap.cpp.

222 {
223  return s_appmgrInstance && s_svclocInstance->existsService( name );
224 }
virtual bool existsService(const std::string &name) const =0
Check the existence of a service given a service name.
StatusCode Gaudi::BootSvcLocator::getService ( const Gaudi::Utils::TypeNameString typeName,
const InterfaceID iid,
IInterface *&  pinterface 
)
override

Definition at line 193 of file Bootstrap.cpp.

195 {
197  if ( s_appmgrInstance ) {
198  sc = s_svclocInstance->getService( typeName, iid, pinterface );
199  } else {
200  pinterface = s_bootInterface.get();
201  }
202  return sc;
203 }
constexpr static const auto FAILURE
Definition: StatusCode.h:88
TYPE * get() const
Get interface pointer.
Definition: SmartIF.h:82
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
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
StatusCode Gaudi::BootSvcLocator::getService ( const Gaudi::Utils::TypeNameString typeName,
IService *&  svc,
const bool  createIf = true 
)
override

Definition at line 204 of file Bootstrap.cpp.

206 {
208  if ( s_appmgrInstance ) {
209  sc = s_svclocInstance->getService( typeName, svc, createIf );
210  } else {
211  svc = s_bootService.get();
212  }
213  return sc;
214 }
constexpr static const auto FAILURE
Definition: StatusCode.h:88
TYPE * get() const
Get interface pointer.
Definition: SmartIF.h:82
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
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
const std::list< IService * > & Gaudi::BootSvcLocator::getServices ( ) const
override

Definition at line 217 of file Bootstrap.cpp.

218 {
219  return s_appmgrInstance ? s_svclocInstance->getServices() : s_bootServices;
220 }
virtual const std::list< IService * > & getServices() const =0
Get a reference to a service and create it if it does not exists.
SmartIF< IService > & Gaudi::BootSvcLocator::service ( const Gaudi::Utils::TypeNameString typeName,
const bool  createIf = true 
)
override

Returns a smart pointer to a service.

Definition at line 226 of file Bootstrap.cpp.

227 {
228  return s_appmgrInstance ? s_svclocInstance->service( typeName, createIf ) : s_bootService;
229 }
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: