This pure template abstract class is a base class for COM encapsulation. More...
#include <ilviews/windows/com.h>
Public Member Functions | |
virtual | ~IlvAbstractCOMInterface ()=0 |
Destructor. More... | |
INTERFACE * | getInterface () const |
This member function returns the interface associated to this class. More... | |
operator INTERFACE * () const | |
This operator returns the interface associated to this class. More... | |
operator INTERFACE const * () const | |
This const operator returns the interface associated to this class. More... | |
INTERFACE * | operator-> () const |
This operator lets the class to be used as a plain pointer. More... | |
void | setInterface (INTERFACE *interf) |
This function replaces the previous interface stored in this object by a new one. More... | |
HRESULT | setInterface (IUnknown *iunk, REFIID iid) |
This function modifies the interface stored by this object through a call to the function QueryInterface of the IUnknown interface. More... | |
Protected Member Functions | |
IlvAbstractCOMInterface () | |
Default constructor. More... | |
IlvAbstractCOMInterface (CntPtr const &initObj) | |
Constructor. More... | |
IlvAbstractCOMInterface (IlvAbstractCOMInterface const &other) | |
Copy constructor. More... | |
CntPtr const & | getInitializer () const |
This function returns a reference counter to the library initializer. More... | |
IlvAbstractCOMInterface & | operator= (IlvAbstractCOMInterface const &other) |
Assignment operator. More... | |
This pure template abstract class is a base class for COM encapsulation.
Library: ilvcom
It defines the member function to return an interface. The type of the interface is given as parameter of the template.
|
pure virtual |
Destructor.
It releases the interface if necessary. It is defined as a pure virtual function.
|
protected |
Default constructor.
The constructors are protected and can only be used in derived classes. This one just initializes the internal data members and initializes the COM library, if needed, through _initializeObject
.
|
protected |
Copy constructor.
The constructors are protected and can only be used in derived classes. This one just initializes the internal data members by copying the values from the object other
. It does not initialize the COM library.
|
protected |
Constructor.
The constructors are protected and can only be used in derived classes. This one just initializes the internal data members to default values. The _initializeObject
data member is a copy of initObj. It does not initialize the COM library.
initObj | Must only be a reference to a reference counter to an IlvCOMLibraryInitialization object. |
|
protected |
This function returns a reference counter to the library initializer.
This function can only be used in the inherited classes.
IlvAbstractLibraryInitialization
object. INTERFACE * IlvAbstractCOMInterface< INTERFACE >::getInterface |
This member function returns the interface associated to this class.
IlvAbstractCOMInterface< INTERFACE >::operator INTERFACE * |
This operator returns the interface associated to this class.
IlvAbstractCOMInterface< INTERFACE >::operator INTERFACE const * | ( | ) | const |
This const operator returns the interface associated to this class.
INTERFACE * IlvAbstractCOMInterface< INTERFACE >::operator-> |
This operator lets the class to be used as a plain pointer.
|
protected |
Assignment operator.
This operator assigns the given IlvAbstractCOMInterface<INTERFACE>
to this
. It returns *this
.
other | A constant reference to an IlvAbstractCOMInterface<INTERFACE> object. |
void IlvAbstractCOMInterface< INTERFACE >::setInterface | ( | INTERFACE * | interf | ) |
This function replaces the previous interface stored in this object by a new one.
If the previous interface was not null
, then the function Release
is called for the previous interface stored by the object. It the new interface is not null
, the function AddRef
is called for this new interface.
HRESULT IlvAbstractCOMInterface< INTERFACE >::setInterface | ( | IUnknown * | iunk, |
REFIID | iid | ||
) |
This function modifies the interface stored by this object through a call to the function QueryInterface
of the IUnknown
interface.
When an error occurs, the interface is not changed. Otherwise the function Release
is called for the previous interface stored by the object (if any).