changed its signature to take a const reference instead of a pointer which simplifies the code and makes it safer as well git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@42776 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
		
			
				
	
	
		
			242 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			TeX
		
	
	
	
	
	
			
		
		
	
	
			242 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			TeX
		
	
	
	
	
	
| \section{\class{wxObject}}\label{wxobject}
 | |
| 
 | |
| This is the root class of all wxWidgets classes.
 | |
| It declares a virtual destructor which ensures that
 | |
| destructors get called for all derived class objects where necessary.
 | |
| 
 | |
| wxObject is the hub of a dynamic object creation
 | |
| scheme, enabling a program to create instances of a class only knowing
 | |
| its string class name, and to query the class hierarchy.
 | |
| 
 | |
| The class contains optional debugging versions
 | |
| of {\bf new} and {\bf delete}, which can help trace memory allocation
 | |
| and deallocation problems.
 | |
| 
 | |
| wxObject can be used to implement \helpref{reference counted}{trefcount} objects,
 | |
| such as wxPen, wxBitmap and others (see \helpref{this list}{refcountlist}).
 | |
| 
 | |
| \wxheading{See also}
 | |
| 
 | |
| \helpref{wxClassInfo}{wxclassinfo}, \helpref{Debugging overview}{debuggingoverview},\rtfsp
 | |
| \helpref{wxObjectRefData}{wxobjectrefdata}
 | |
| 
 | |
| \latexignore{\rtfignore{\wxheading{Members}}}
 | |
| 
 | |
| \membersection{wxObject::wxObject}\label{wxobjectctor}
 | |
| 
 | |
| \func{}{wxObject}{\void}
 | |
| 
 | |
| \func{}{wxObject}{\param{const wxObject\&}{ other}}
 | |
| 
 | |
| Default and copy constructors.
 | |
| 
 | |
| \membersection{wxObject::\destruct{wxObject}}\label{wxobjectdtor}
 | |
| 
 | |
| \func{}{wxObject}{\void}
 | |
| 
 | |
| Destructor. Performs dereferencing, for those objects
 | |
| that use reference counting.
 | |
| 
 | |
| \membersection{wxObject::m\_refData}\label{wxobjectmrefdata}
 | |
| 
 | |
| \member{wxObjectRefData* }{m\_refData}
 | |
| 
 | |
| Pointer to an object which is the object's reference-counted data.
 | |
| 
 | |
| \wxheading{See also}
 | |
| 
 | |
| \helpref{wxObject::Ref}{wxobjectref}, \helpref{wxObject::UnRef}{wxobjectunref},\rtfsp
 | |
| \helpref{wxObject::SetRefData}{wxobjectsetrefdata},\rtfsp
 | |
| \helpref{wxObject::GetRefData}{wxobjectgetrefdata},\rtfsp
 | |
| \helpref{wxObjectRefData}{wxobjectrefdata}
 | |
| 
 | |
| \membersection{wxObject::Dump}\label{wxobjectdump}
 | |
| 
 | |
| \func{void}{Dump}{\param{ostream\&}{ stream}}
 | |
| 
 | |
| A virtual function that may be redefined by derived classes to allow dumping of
 | |
| memory states.
 | |
| 
 | |
| This function is only defined in debug build and doesn't exist at all if
 | |
| {\tt \_\_WXDEBUG\_\_} is not defined.
 | |
| 
 | |
| \wxheading{Parameters}
 | |
| 
 | |
| \docparam{stream}{Stream on which to output dump information.}
 | |
| 
 | |
| \wxheading{Remarks}
 | |
| 
 | |
| Currently wxWidgets does not define Dump for derived classes, but
 | |
| programmers may wish to use it for their own applications. Be sure to
 | |
| call the Dump member of the class's base class to allow all information to be
 | |
| dumped.
 | |
| 
 | |
| The implementation of this function in wxObject just writes the class name of
 | |
| the object.
 | |
| 
 | |
| \membersection{wxObject::GetClassInfo}\label{wxobjectgetclassinfo}
 | |
| 
 | |
| \func{wxClassInfo *}{GetClassInfo}{\void}
 | |
| 
 | |
| This virtual function is redefined for every class that requires run-time
 | |
| type information, when using DECLARE\_CLASS macros.
 | |
| 
 | |
| \membersection{wxObject::GetRefData}\label{wxobjectgetrefdata}
 | |
| 
 | |
| \constfunc{wxObjectRefData*}{GetRefData}{\void}
 | |
| 
 | |
| Returns the {\bf m\_refData} pointer.
 | |
| 
 | |
| \wxheading{See also}
 | |
| 
 | |
| \helpref{wxObject::Ref}{wxobjectref}, \helpref{wxObject::UnRef}{wxobjectunref}, \helpref{wxObject::m\_refData}{wxobjectmrefdata},\rtfsp
 | |
| \helpref{wxObject::SetRefData}{wxobjectsetrefdata},\rtfsp
 | |
| \helpref{wxObjectRefData}{wxobjectrefdata}
 | |
| 
 | |
| \membersection{wxObject::IsKindOf}\label{wxobjectiskindof}
 | |
| 
 | |
| \func{bool}{IsKindOf}{\param{wxClassInfo *}{info}}
 | |
| 
 | |
| Determines whether this class is a subclass of (or the same class as)
 | |
| the given class.
 | |
| 
 | |
| \wxheading{Parameters}
 | |
| 
 | |
| \docparam{info}{A pointer to a class information object, which may be obtained
 | |
| by using the CLASSINFO macro.}
 | |
| 
 | |
| \wxheading{Return value}
 | |
| 
 | |
| true if the class represented by {\it info} is the same class as
 | |
| this one or is derived from it.
 | |
| 
 | |
| \wxheading{Example}
 | |
| 
 | |
| \begin{verbatim}
 | |
|   bool tmp = obj->IsKindOf(CLASSINFO(wxFrame));
 | |
| \end{verbatim}
 | |
| 
 | |
| \membersection{wxObject::IsSameAs}\label{wxobjectissameas}
 | |
| 
 | |
| \func{bool}{IsSameAs}{\param{const wxObject\& }{ obj}}
 | |
| 
 | |
| Returns \true if this object has the same data pointer as \arg{obj}. Notice
 | |
| that \true is returned if the data pointers are \NULL in both objects.
 | |
| 
 | |
| This function only does a \emph{shallow} comparison, i.e. it doesn't compare
 | |
| the objects pointed to by the data pointers of these objects.
 | |
| 
 | |
| \membersection{wxObject::Ref}\label{wxobjectref}
 | |
| 
 | |
| \func{void}{Ref}{\param{const wxObject\& }{clone}}
 | |
| 
 | |
| Makes this object refer to the data in {\it clone}.
 | |
| 
 | |
| \wxheading{Parameters}
 | |
| 
 | |
| \docparam{clone}{The object to `clone'.}
 | |
| 
 | |
| \wxheading{Remarks}
 | |
| 
 | |
| First this function calls \helpref{wxObject::UnRef}{wxobjectunref} on itself
 | |
| to decrement (and perhaps free) the data it is currently referring to.
 | |
| 
 | |
| It then sets its own m\_refData to point to that of {\it clone}, and increments the reference count
 | |
| inside the data.
 | |
| 
 | |
| \wxheading{See also}
 | |
| 
 | |
| \helpref{wxObject::UnRef}{wxobjectunref}, \helpref{wxObject::m\_refData}{wxobjectmrefdata},\rtfsp
 | |
| \helpref{wxObject::SetRefData}{wxobjectsetrefdata}, \helpref{wxObject::GetRefData}{wxobjectgetrefdata},\rtfsp
 | |
| \helpref{wxObjectRefData}{wxobjectrefdata}
 | |
| 
 | |
| \membersection{wxObject::SetRefData}\label{wxobjectsetrefdata}
 | |
| 
 | |
| \func{void}{SetRefData}{\param{wxObjectRefData*}{ data}}
 | |
| 
 | |
| Sets the {\bf m\_refData} pointer.
 | |
| 
 | |
| \wxheading{See also}
 | |
| 
 | |
| \helpref{wxObject::Ref}{wxobjectref}, \helpref{wxObject::UnRef}{wxobjectunref}, \helpref{wxObject::m\_refData}{wxobjectmrefdata},\rtfsp
 | |
| \helpref{wxObject::GetRefData}{wxobjectgetrefdata},\rtfsp
 | |
| \helpref{wxObjectRefData}{wxobjectrefdata}
 | |
| 
 | |
| \membersection{wxObject::UnRef}\label{wxobjectunref}
 | |
| 
 | |
| \func{void}{UnRef}{\void}
 | |
| 
 | |
| Decrements the reference count in the associated data, and if it is zero, deletes the data.
 | |
| The {\bf m\_refData} member is set to NULL.
 | |
| 
 | |
| \wxheading{See also}
 | |
| 
 | |
| \helpref{wxObject::Ref}{wxobjectref}, \helpref{wxObject::m\_refData}{wxobjectmrefdata},\rtfsp
 | |
| \helpref{wxObject::SetRefData}{wxobjectsetrefdata}, \helpref{wxObject::GetRefData}{wxobjectgetrefdata},\rtfsp
 | |
| \helpref{wxObjectRefData}{wxobjectrefdata}
 | |
| 
 | |
| \membersection{wxObject::UnShare}\label{wxobjectunshare}
 | |
| 
 | |
| \func{void}{UnShare}{\void}
 | |
| 
 | |
| Ensure that this object's data is not shared with any other object.
 | |
| 
 | |
| if we have no
 | |
| data, it is created using CreateRefData() below, if we have shared data
 | |
| it is copied using CloneRefData(), otherwise nothing is done.
 | |
| 
 | |
| 
 | |
| \membersection{wxObject::operator new}\label{wxobjectnew}
 | |
| 
 | |
| \func{void *}{new}{\param{size\_t }{size}, \param{const wxString\& }{filename = NULL}, \param{int}{ lineNum = 0}}
 | |
| 
 | |
| The {\it new} operator is defined for debugging versions of the library only, when
 | |
| the identifier \_\_WXDEBUG\_\_ is defined. It takes over memory allocation, allowing
 | |
| wxDebugContext operations.
 | |
| 
 | |
| \membersection{wxObject::operator delete}\label{wxobjectdelete}
 | |
| 
 | |
| \func{void}{delete}{\param{void }{buf}}
 | |
| 
 | |
| The {\it delete} operator is defined for debugging versions of the library only, when
 | |
| the identifier \_\_WXDEBUG\_\_ is defined. It takes over memory deallocation, allowing
 | |
| wxDebugContext operations.
 | |
| 
 | |
| \section{\class{wxObjectRefData}}\label{wxobjectrefdata}
 | |
| 
 | |
| This class is used to store reference-counted data. Derive classes from this to
 | |
| store your own data. When retrieving information from a {\bf wxObject}'s reference data,
 | |
| you will need to cast to your own derived class.
 | |
| 
 | |
| \wxheading{Friends}
 | |
| 
 | |
| \helpref{wxObject}{wxobject}
 | |
| 
 | |
| \wxheading{See also}
 | |
| 
 | |
| \helpref{wxObject}{wxobject}
 | |
| 
 | |
| \latexignore{\rtfignore{\wxheading{Members}}}
 | |
| 
 | |
| 
 | |
| \membersection{wxObjectRefData::wxObjectRefData}\label{wxobjectrefdatactor}
 | |
| 
 | |
| \func{}{wxObjectRefData}{\void}
 | |
| 
 | |
| Default constructor. Initialises the {\bf m\_count} member to 1.
 | |
| 
 | |
| \membersection{wxObjectRefData::\destruct{wxObjectRefData}}\label{wxobjectrefdatadtor}
 | |
| 
 | |
| \func{}{wxObjectRefData}{\void}
 | |
| 
 | |
| Destructor.
 | |
| 
 | |
| \membersection{wxObjectRefData::GetRefCount}\label{wxobjectrefdatagetrefcount}
 | |
| 
 | |
| \constfunc{int}{GetRefCount}{\void}
 | |
| 
 | |
| Returns the reference count associated with this shared data.
 | |
| When this goes to zero during a \helpref{wxObject::UnRef}{wxobjectunref}, an object
 | |
| can delete this {\bf wxObjectRefData} object.
 | |
| 
 |