PTLib  Version 2.18.8
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
PNotifierFunctionTemplate< ParamType > Class Template Referenceabstract

This is an abstract class for which a descendent is declared for every function that may be called. More...

#include <notifier.h>

Inheritance diagram for PNotifierFunctionTemplate< ParamType >:
Collaboration diagram for PNotifierFunctionTemplate< ParamType >:

Public Member Functions

virtual void Call (PObject &notifier, ParamType extra) const =0
 Execute the call to the actual notification function on the object instance contained in this object. More...
 
virtual void * GetTarget () const
 
- Public Member Functions inherited from PObject
__inline unsigned GetTraceContextIdentifier () const
 Get PTRACE context identifier. More...
 
__inline void SetTraceContextIdentifier (unsigned id)
 
__inline void SetTraceContextIdentifier (const PObject &obj)
 
__inline void SetTraceContextIdentifier (const PObject *obj)
 
__inline void CopyTraceContextIdentifier (PObject &obj) const
 
__inline void CopyTraceContextIdentifier (PObject *obj) const
 
virtual ~PObject ()
 
__inline const char * GetClass () const
 
__inline bool IsClass (const char *name) const
 
__inline const PObjectPTraceObjectInstance () const
 
virtual PObjectClone () const
 Create a copy of the class on the heap. More...
 
template<class CLS >
CLS * CloneAs () const
 As for Clone() but converts to specified type. More...
 
virtual PINDEX HashFunction () const
 This function yields a hash value required by the PDictionary class. More...
 
virtual Comparison Compare (const PObject &obj) const
 Compare the two objects and return their relative rank. More...
 
virtual Comparison CompareObjectMemoryDirect (const PObject &obj) const
 Determine the byte wise comparison of two objects. More...
 
bool operator== (const PObject &obj) const
 Compare the two objects. More...
 
bool operator!= (const PObject &obj) const
 Compare the two objects. More...
 
bool operator< (const PObject &obj) const
 Compare the two objects. More...
 
bool operator> (const PObject &obj) const
 Compare the two objects. More...
 
bool operator<= (const PObject &obj) const
 Compare the two objects. More...
 
bool operator>= (const PObject &obj) const
 Compare the two objects. More...
 
virtual void PrintOn (ostream &strm) const
 Output the contents of the object to the stream. More...
 
virtual void ReadFrom (istream &strm)
 Input the contents of the object from the stream. More...
 

Protected Member Functions

 PNotifierFunctionTemplate (void *target, void *=NULL)
 Create a notification function instance. More...
 
- Protected Member Functions inherited from PSmartObject
 PSmartObject ()
 Construct a new smart object, subject to a PSmartPointer instance referencing it. More...
 
 PSmartObject (const PSmartObject &other)
 
- Protected Member Functions inherited from PObject
 PObject ()
 Constructor for PObject, made protected so cannot ever create one on its own. More...
 

Protected Attributes

void * m_target
 Object instance to receive the notification function call. More...
 
- Protected Attributes inherited from PSmartObject
atomic< uint32_t > referenceCount
 Count of number of instances of PSmartPointer that currently reference the object instance. More...
 
- Protected Attributes inherited from PObject
unsigned m_traceContextIdentifier
 

Additional Inherited Members

- Public Types inherited from PObject
enum  Comparison { LessThan = -1, EqualTo = 0, GreaterThan = 1 }
 Result of the comparison operation performed by the Compare() function. More...
 
- Static Public Member Functions inherited from PObject
static __inline void CopyTraceContextIdentifier (PObject &to, const PObject &from)
 
static __inline void CopyTraceContextIdentifier (PObject &to, const PObject *from)
 
static __inline void CopyTraceContextIdentifier (PObject *to, const PObject &from)
 
static __inline void CopyTraceContextIdentifier (PObject *to, const PObject *from)
 
static __inline const char * Class ()
 
static __inline const PObjectPTraceObjectInstance (const char *)
 
static __inline const PObjectPTraceObjectInstance (const PObject *obj)
 
template<typename T >
static Comparison Compare2 (T v1, T v2)
 Compare two types, returning Comparison type. More...
 
static Comparison InternalCompareObjectMemoryDirect (const PObject *obj1, const PObject *obj2, PINDEX size)
 Internal function caled from CompareObjectMemoryDirect() More...
 

Detailed Description

template<typename ParamType>
class PNotifierFunctionTemplate< ParamType >

This is an abstract class for which a descendent is declared for every function that may be called.

The PDECLARE_NOTIFIER macro makes this declaration.

The PNotifier and PNotifierFunction classes build a completely type safe mechanism for calling arbitrary member functions on classes. The "pointer to a member function" capability built into C++ makes the assumption that the function name exists in an ancestor class. If you wish to call a member function name that does not exist in any ancestor class, very type unsafe casting of the member functions must be made. Some compilers will even refuse to do it at all!

To overcome this problem, as this mechanism is highly desirable for callback functions in the GUI part of the PTLib library, these classes and a macro are used to create all the classes and declarations to use polymorphism as the link between the caller, which has no knowledege of the function, and the receiver object and member function.

This is most often used as the notification of actions being take by interactors in the PTLib library.

Constructor & Destructor Documentation

template<typename ParamType >
PNotifierFunctionTemplate< ParamType >::PNotifierFunctionTemplate ( void *  target,
void *  = NULL 
)
inlineprotected

Create a notification function instance.

Parameters
targetObject instance on which the function will be called on.

References PNotifierFunctionTemplate< ParamType >::m_target, and PAssertNULL.

Member Function Documentation

template<typename ParamType >
virtual void PNotifierFunctionTemplate< ParamType >::Call ( PObject notifier,
ParamType  extra 
) const
pure virtual

Execute the call to the actual notification function on the object instance contained in this object.

Parameters
notifierObject that is making the notification.
extraExtra information that may be passed to function.

Referenced by PNotifierTemplate< PChannel::AsyncContext & >::operator()().

template<typename ParamType >
virtual void* PNotifierFunctionTemplate< ParamType >::GetTarget ( ) const
inlinevirtual

Member Data Documentation

template<typename ParamType >
void* PNotifierFunctionTemplate< ParamType >::m_target
protected

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