![]() |
The Gaudi Framework
v26r3
|
A dual-stage boostrap mechanism is used to ensure an orderly startup of the ApplicationMgr. More...
Public Member Functions | |
BootSvcLocator () | |
virtual | ~BootSvcLocator () |
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 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 const std::list< IService * > & | getServices () const |
Get a reference to a service and create it if it does not exists. More... | |
virtual bool | existsService (const std::string &name) const |
Check the existence of a service given a service name. More... | |
virtual SmartIF< IService > & | service (const Gaudi::Utils::TypeNameString &typeName, const bool createIf=true) |
Returns a smart pointer to a service. More... | |
![]() | |
virtual | ~extend_interfaces1 () |
Virtual destructor. More... | |
virtual | ~extend_interfaces1 () |
Virtual destructor. More... | |
![]() | |
DeclareInterfaceID (ISvcLocator, 3, 0) | |
InterfaceID. 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... | |
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... | |
DeclareInterfaceID (ISvcLocator, 3, 0) | |
InterfaceID. 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... | |
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... | |
![]() | |
virtual void * | i_cast (const InterfaceID &) const =0 |
main cast function More... | |
virtual std::vector< std::string > | getInterfaceNames () 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 () |
Virtual destructor. More... | |
virtual void * | i_cast (const InterfaceID &) const =0 |
main cast function More... | |
virtual std::vector< std::string > | getInterfaceNames () 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 () |
Virtual destructor. More... | |
Additional Inherited Members | |
![]() | |
typedef implements1 | base_class |
Typedef to this class. More... | |
typedef implements1 | base_class |
Typedef to this class. More... | |
typedef extend_interfaces1< ISvcLocator > | extend_interfaces_base |
Typedef to the base of this class. More... | |
typedef extend_interfaces1< ISvcLocator > | extend_interfaces_base |
Typedef to the base of this class. More... | |
typedef extend_interfaces_base::ext_iids | interfaces |
MPL set of all the implemented interfaces. More... | |
typedef extend_interfaces_base::ext_iids | interfaces |
MPL set of all the implemented interfaces. More... | |
![]() | |
typedef ISvcLocator::iid::iids::type | ext_iids |
MPL set of interfaces extended by this one. More... | |
typedef ISvcLocator::iid::iids::type | ext_iids |
MPL set of interfaces extended by this one. More... | |
![]() | |
enum | Status { SUCCESS = 1, NO_INTERFACE, VERSMISMATCH, LAST_ERROR, SUCCESS = 1, NO_INTERFACE, VERSMISMATCH, LAST_ERROR } |
Return status. More... | |
enum | Status { SUCCESS = 1, NO_INTERFACE, VERSMISMATCH, LAST_ERROR, SUCCESS = 1, NO_INTERFACE, VERSMISMATCH, LAST_ERROR } |
Return status. More... | |
typedef Gaudi::InterfaceId< IInterface, 0, 0 > | iid |
Interface ID. More... | |
typedef mpl::set1< iid > | ext_iids |
Extra interfaces. More... | |
typedef Gaudi::InterfaceId< IInterface, 0, 0 > | iid |
Interface ID. More... | |
typedef mpl::set1< iid > | ext_iids |
Extra interfaces. More... | |
![]() | |
static const InterfaceID & | interfaceID () |
Return an instance of InterfaceID identifying the interface. More... | |
static const InterfaceID & | interfaceID () |
Return an instance of InterfaceID identifying the interface. More... | |
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.
BootSvcLocator::BootSvcLocator | ( | ) |
Definition at line 218 of file Bootstrap.cpp.
|
virtual |
Definition at line 220 of file Bootstrap.cpp.
|
virtual |
Check the existence of a service given a service name.
Implements ISvcLocator.
Definition at line 256 of file Bootstrap.cpp.
|
virtual |
Get a specific interface pointer given a service name and interface id.
name | Service name |
iid | Interface ID |
pinterface | Returned pointer to the requested interface |
Reimplemented from ISvcLocator.
Definition at line 224 of file Bootstrap.cpp.
|
virtual |
Get a reference to the service given a service name.
name | Service name |
svc | Returned service pointer |
Reimplemented from ISvcLocator.
Definition at line 235 of file Bootstrap.cpp.
|
virtual |
Get a reference to a service and create it if it does not exists.
name | Service name |
svc | Returned service pointer |
createIf | flag to control the creationReturn the list of Services |
Implements ISvcLocator.
Definition at line 248 of file Bootstrap.cpp.
|
virtual |
Returns a smart pointer to a service.
Implements ISvcLocator.
Definition at line 265 of file Bootstrap.cpp.