#include <wx/object.h>
This is an helper template class primarily written to avoid memory leaks because of missing calls to wxRefCounter::DecRef() and wxObjectRefData::DecRef().
Despite the name this template can actually be used as a smart pointer for any class implementing the reference counting interface which only consists of the two methods T::IncRef() and T::DecRef().
The difference to wxSharedPtr<T> is that wxObjectDataPtr<T> relies on the reference counting to be in the class pointed to, where instead wxSharedPtr<T> implements the reference counting itself.
Below is an example illustrating how to implement reference counted data using wxRefCounter and wxObjectDataPtr<T> with copy-on-write semantics.
| Public Member Functions | |
| wxObjectDataPtr (T *ptr=NULL) | |
| Constructor.  More... | |
| wxObjectDataPtr (const wxObjectDataPtr< T > &tocopy) | |
| This copy constructor increases the count of the reference counted object to which tocopy points and then this class will point to, as well.  More... | |
| ~wxObjectDataPtr () | |
| Decreases the reference count of the object to which this class points.  More... | |
| T * | get () const | 
| Gets a pointer to the reference counted object to which this class points.  More... | |
| void | reset (T *ptr) | 
| Reset this class to ptr which points to a reference counted object and calls T::DecRef() on the previously owned object.  More... | |
| operator unspecified_bool_type () const | |
| Conversion to a boolean expression (in a variant which is not convertable to anything but a boolean expression).  More... | |
| T & | operator* () const | 
| Returns a reference to the object.  More... | |
| T * | operator-> () const | 
| Returns a pointer to the reference counted object to which this class points.  More... | |
| wxObjectDataPtr< T > & | operator= (const wxObjectDataPtr< T > &tocopy) | 
| Assignment operator.  More... | |
| wxObjectDataPtr< T > & | operator= (T *ptr) | 
| Assignment operator.  More... | |
| wxObjectDataPtr< T >::wxObjectDataPtr | ( | T * | ptr = NULL | ) | 
Constructor.
ptr is a pointer to the reference counted object to which this class points. If ptr is not NULL T::IncRef() will be called on the object.
| wxObjectDataPtr< T >::wxObjectDataPtr | ( | const wxObjectDataPtr< T > & | tocopy | ) | 
This copy constructor increases the count of the reference counted object to which tocopy points and then this class will point to, as well.
| wxObjectDataPtr< T >::~wxObjectDataPtr | ( | ) | 
Decreases the reference count of the object to which this class points.
| T* wxObjectDataPtr< T >::get | ( | ) | const | 
Gets a pointer to the reference counted object to which this class points.
| wxObjectDataPtr< T >::operator unspecified_bool_type | ( | ) | const | 
Conversion to a boolean expression (in a variant which is not convertable to anything but a boolean expression).
If this class contains a valid pointer it will return true, if it contains a NULL pointer it will return false.
| T& wxObjectDataPtr< T >::operator* | ( | ) | const | 
Returns a reference to the object.
If the internal pointer is NULL this method will cause an assert in debug mode.
| T* wxObjectDataPtr< T >::operator-> | ( | ) | const | 
Returns a pointer to the reference counted object to which this class points.
If this the internal pointer is NULL, this method will assert in debug mode.
| wxObjectDataPtr<T>& wxObjectDataPtr< T >::operator= | ( | const wxObjectDataPtr< T > & | tocopy | ) | 
Assignment operator.
| wxObjectDataPtr<T>& wxObjectDataPtr< T >::operator= | ( | T * | ptr | ) | 
Assignment operator.
| void wxObjectDataPtr< T >::reset | ( | T * | ptr | ) | 
Reset this class to ptr which points to a reference counted object and calls T::DecRef() on the previously owned object.