ADTF
default_object< inherit_from< Parents... >, expose_interfaces< Interfaces... >, Child >

Used to implement IObject::GetInterface() methods with given interfaces to expose. More...

Inheritance diagram for default_object< inherit_from< Parents... >, expose_interfaces< Interfaces... >, Child >:
[legend]

Public Types

typedef interface_expose< Interfaces... > interface_expose_type
 Enables accessing the exposed interfaces via typedef (e.g. for ucom_cast<> access)
 

Protected Member Functions

virtual ~default_object ()
 Virtual destructor needed for call to this->Destroy()
 
virtual tResult GetInterface (const char *i_strIID, void *&o_pInterface)
 Default implementation of IObject::GetInterface() More...
 
virtual tResult GetInterface (const char *i_strIID, const void *&o_pInterface) const
 Default implementation of IObject::GetInterface() provided for const correctness. More...
 
virtual void Destroy () const
 Default implementation to destroy an object of this type.
 

Detailed Description

template<typename Child, typename ... Interfaces, typename ... Parents>
class adtf::ucom::ant::default_object< inherit_from< Parents... >, expose_interfaces< Interfaces... >, Child >

Used to implement IObject::GetInterface() methods with given interfaces to expose.

This template class is intended as subclass of a concrete implementation of IObject. When inheriting from this class, two template parameters of type inherit_from and expose_interfaces, both being variadic templates themselves, must be given. With struct inherit_from those types are given which default_object itself uses as its parents in form of multiple inheritance. As default_object itself must be inherited by the concrete implementation of the given subclassed interfaces, it marks some kind of intermediate layer only used to implement IObject::GetInterface() methods. With struct expose_interfaces the interfaces to expose are given.

See also
Section The "elaborate" way (aka "object<>") in page The ucom_cast<> in depth explanation
Template Parameters
ChildChild type of this default_object and is only needed if UCOM_RESOLVE() is given in child class Child
InterfacesThe interfaces to expose
ParentsThe parent classes to derive default_object from (flat hierarchy)

Definition at line 638 of file adtf_iid.h.

Member Function Documentation

◆ GetInterface() [1/2]

virtual tResult GetInterface ( const char *  i_strIID,
const void *&  o_pInterface 
) const
inlineprotectedvirtual

Default implementation of IObject::GetInterface() provided for const correctness.

Using the interface types given with expose_interfaces, meta struct template interface_expose is used to evaluate whether the interface identified with i_strIID is exposed by this.

Parameters
[in]i_strIIDIdentifier of the interface being requested.
[out]o_pInterfaceAddress of pointer variable that receives the interface pointer requested in idInterface. Upon successful return, *o_pInterface contains the requested interface pointer to the object. If the object does not expose the interface specified in i_strIID, i_pInterface is set to NULL.
Returns
Standard error.
Return values
ERR_NOERRORThe interface identified by i_strIID was implemented and exposed by the implementation of *this. o_pInterface points to the queried interface.
ERR_NO_INTERFACEThe requested interface is not exposed. o_pInterface==NULL

Definition at line 691 of file adtf_iid.h.

◆ GetInterface() [2/2]

virtual tResult GetInterface ( const char *  i_strIID,
void *&  o_pInterface 
)
inlineprotectedvirtual

Default implementation of IObject::GetInterface()

Using the interface types given with expose_interfaces, meta struct template interface_expose is used to evaluate whether the interface identified with i_strIID is exposed by this.

Parameters
[in]i_strIIDIdentifier of the interface being requested.
[out]o_pInterfaceAddress of pointer variable that receives the interface pointer requested in idInterface. Upon successful return, *o_pInterface contains the requested interface pointer to the object. If the object does not expose the interface specified in i_strIID, i_pInterface is set to NULL.
Returns
Standard error.
Return values
ERR_NOERRORThe interface identified by i_strIID was implemented and exposed by the implementation of *this. o_pInterface points to the queried interface.
ERR_NO_INTERFACEThe requested interface is not exposed. o_pInterface==NULL

Definition at line 668 of file adtf_iid.h.