PTLib
Version 2.18.8
|
This is an abstract class for which a descendent is declared for every function that may be called. More...
#include <notifier.h>
Public Member Functions | |
virtual void | Call (PObject ¬ifier, 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 |
![]() | |
__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 PObject * | PTraceObjectInstance () const |
virtual PObject * | Clone () 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... | |
![]() | |
PSmartObject () | |
Construct a new smart object, subject to a PSmartPointer instance referencing it. More... | |
PSmartObject (const PSmartObject &other) | |
![]() | |
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... | |
![]() | |
atomic< uint32_t > | referenceCount |
Count of number of instances of PSmartPointer that currently reference the object instance. More... | |
![]() | |
unsigned | m_traceContextIdentifier |
Additional Inherited Members | |
![]() | |
enum | Comparison { LessThan = -1, EqualTo = 0, GreaterThan = 1 } |
Result of the comparison operation performed by the Compare() function. More... | |
![]() | |
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 PObject * | PTraceObjectInstance (const char *) |
static __inline const PObject * | PTraceObjectInstance (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... | |
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.
|
inlineprotected |
Create a notification function instance.
target | Object instance on which the function will be called on. |
References PNotifierFunctionTemplate< ParamType >::m_target, and PAssertNULL.
|
pure virtual |
Execute the call to the actual notification function on the object instance contained in this object.
notifier | Object that is making the notification. |
extra | Extra information that may be passed to function. |
Referenced by PNotifierTemplate< PChannel::AsyncContext & >::operator()().
|
inlinevirtual |
Reimplemented in PValidatedNotifierFunction< ParamType >.
References PNotifierFunctionTemplate< ParamType >::m_target.
Referenced by PNotifierTemplate< PChannel::AsyncContext & >::GetTarget().
|
protected |
Object instance to receive the notification function call.
Referenced by PNotifierFunctionTemplate< ParamType >::GetTarget(), PValidatedNotifierFunction< ParamType >::GetTarget(), and PNotifierFunctionTemplate< ParamType >::PNotifierFunctionTemplate().