2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: clntdata.h
|
2008-03-10 15:24:38 +00:00
|
|
|
// Purpose: interface of wxClientDataContainer
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Licence: wxWindows license
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxClientDataContainer
|
|
|
|
@wxheader{clntdata.h}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
This class is a mixin that provides storage and management of "client
|
|
|
|
data." This data can either be of type void - in which case the data
|
|
|
|
@e container does not take care of freeing the data again
|
|
|
|
or it is of type wxClientData or its derivatives. In that case the
|
|
|
|
container will free the memory itself later.
|
|
|
|
Note that you @e must not assign both void data and data
|
|
|
|
derived from the wxClientData class to a container.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
NOTE: This functionality is currently duplicated in wxEvtHandler in
|
|
|
|
order to avoid having more than one vtable in that class hierarchy.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxbase}
|
|
|
|
@category{FIXME}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxEvtHandler, wxClientData
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-08 14:43:31 +00:00
|
|
|
class wxClientDataContainer
|
2008-03-08 13:52:38 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
wxClientDataContainer();
|
|
|
|
|
|
|
|
/**
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
~wxClientDataContainer();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Get the untyped client data.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
void* GetClientData() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Get a pointer to the client data object.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxClientData* GetClientObject() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Set the untyped client data.
|
|
|
|
*/
|
|
|
|
void SetClientData(void* data);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set the client data object. Any previous object will be deleted.
|
|
|
|
*/
|
|
|
|
void SetClientObject(wxClientData* data);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
@class wxClientData
|
|
|
|
@wxheader{clntdata.h}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
All classes deriving from wxEvtHandler
|
|
|
|
(such as all controls and wxApp)
|
|
|
|
can hold arbitrary data which is here referred to as "client data".
|
|
|
|
This is useful e.g. for scripting languages which need to handle
|
|
|
|
shadow objects for most of wxWidgets' classes and which store
|
|
|
|
a handle to such a shadow class as client data in that class.
|
|
|
|
This data can either be of type void - in which case the data
|
|
|
|
@e container does not take care of freeing the data again
|
|
|
|
or it is of type wxClientData or its derivatives. In that case the
|
|
|
|
container (e.g. a control) will free the memory itself later.
|
|
|
|
Note that you @e must not assign both void data and data
|
|
|
|
derived from the wxClientData class to a container.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Some controls can hold various items and these controls can
|
|
|
|
additionally hold client data for each item. This is the case for
|
|
|
|
wxChoice, wxComboBox
|
|
|
|
and wxListBox. wxTreeCtrl
|
|
|
|
has a specialized class wxTreeItemData
|
|
|
|
for each item in the tree.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
If you want to add client data to your own classes, you may
|
|
|
|
use the mix-in class wxClientDataContainer.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxbase}
|
|
|
|
@category{FIXME}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxEvtHandler, wxTreeItemData, wxStringClientData, wxClientDataContainer
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-08 14:43:31 +00:00
|
|
|
class wxClientData
|
2008-03-08 13:52:38 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Constructor.
|
|
|
|
*/
|
|
|
|
wxClientData();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Virtual destructor.
|
|
|
|
*/
|
|
|
|
~wxClientData();
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
@class wxStringClientData
|
|
|
|
@wxheader{clntdata.h}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Predefined client data class for holding a string.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxbase}
|
|
|
|
@category{FIXME}
|
|
|
|
*/
|
|
|
|
class wxStringClientData : public wxClientData
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Create client data with string.
|
|
|
|
*/
|
|
|
|
wxStringClientData();
|
2008-03-08 14:43:31 +00:00
|
|
|
wxStringClientData(const wxString& data);
|
2008-03-08 13:52:38 +00:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Get string client data.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
const wxString GetData() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Set string client data.
|
|
|
|
*/
|
|
|
|
void SetData(const wxString& data);
|
|
|
|
};
|
2008-03-10 15:24:38 +00:00
|
|
|
|