1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: A mixin class for holding a wxClientData or void pointer
8 // Copyright: (c) wxWindows team
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
12 #ifndef _WX_CLNTDATAH__
13 #define _WX_CLNTDATAH__
16 #pragma interface "clntdata.h"
20 #include "wx/string.h"
22 // ----------------------------------------------------------------------------
24 // what kind of client data do we have?
27 wxClientData_None
, // we don't know yet because we don't have it at all
28 wxClientData_Object
, // our client data is typed and we own it
29 wxClientData_Void
// client data is untyped and we don't own it
32 class WXDLLEXPORT wxClientData
36 virtual ~wxClientData() { }
39 class WXDLLEXPORT wxStringClientData
: public wxClientData
42 wxStringClientData() { }
43 wxStringClientData( const wxString
&data
) : m_data(data
) { }
44 void SetData( const wxString
&data
) { m_data
= data
; }
45 const wxString
& GetData() const { return m_data
; }
54 // This class is a mixin that provides storage and management of "client
55 // data." The client data stored can either be a pointer to a wxClientData
56 // object in which case it is managed by the container (i.e. it will delete
57 // the data when it's destroyed) or an untyped pointer which won't be deleted
58 // by the window - but not both of them
60 class WXDLLEXPORT wxClientDataContainer
63 wxClientDataContainer();
64 virtual ~wxClientDataContainer();
66 void SetClientObject( wxClientData
*data
) { DoSetClientObject(data
); }
67 wxClientData
*GetClientObject() const { return DoGetClientObject(); }
69 void SetClientData( void *data
) { DoSetClientData(data
); }
70 void *GetClientData() const { return DoGetClientData(); }
73 // The user data: either an object which will be deleted by the container
74 // when it's deleted or some raw pointer which we do nothing with - only
75 // one type of data can be used with the given window (i.e. you cannot set
76 // the void data and then associate the container with wxClientData or vice
80 wxClientData
*m_clientObject
;
84 // client data accessors
85 virtual void DoSetClientObject( wxClientData
*data
);
86 virtual wxClientData
*DoGetClientObject() const;
88 virtual void DoSetClientData( void *data
);
89 virtual void *DoGetClientData() const;
91 // what kind of data do we have?
92 wxClientDataType m_clientDataType
;
96 // ----------------------------------------------------------------------------