]> git.saurik.com Git - wxWidgets.git/blame - include/wx/clntdata.h
A few tweaks and cleanups
[wxWidgets.git] / include / wx / clntdata.h
CommitLineData
88a9f974
RD
1/////////////////////////////////////////////////////////////////////////////
2// Name: wx/clntdata.h
3// Purpose: A mixin class for holding a wxClientData or void pointer
4// Author: Robin Dunn
5// Modified by:
6// Created: 9-Oct-2001
7// RCS-ID: $Id$
8// Copyright: (c) wxWindows team
9// Licence: wxWindows licence
10/////////////////////////////////////////////////////////////////////////////
11
12#ifndef _WX_CLNTDATAH__
13#define _WX_CLNTDATAH__
14
15#ifdef __GNUG__
16d38102 16 #pragma interface "clntdata.h"
88a9f974
RD
17#endif
18
19#include "wx/defs.h"
16d38102 20#include "wx/string.h"
88a9f974
RD
21
22// ----------------------------------------------------------------------------
23
24// what kind of client data do we have?
25enum wxClientDataType
26{
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
30};
31
32class WXDLLEXPORT wxClientData
33{
34public:
35 wxClientData() { }
36 virtual ~wxClientData() { }
37};
38
39class WXDLLEXPORT wxStringClientData : public wxClientData
40{
41public:
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; }
46
47private:
48 wxString m_data;
49};
50
51
16d38102 52
16d38102
RD
53// This class is a mixin that provides storage and management of "client
54// data." The client data stored can either be a pointer to a wxClientData
55// object in which case it is managed by the container (i.e. it will delete
56// the data when it's destroyed) or an untyped pointer which won't be deleted
2aab8f16
RD
57// by the container - but not both of them
58//
59// NOTE: This functionality is currently duplicated in wxEvtHandler in order
60// to avoid having more than one vtable in that class heirachy.
16d38102 61
88a9f974
RD
62class WXDLLEXPORT wxClientDataContainer
63{
64public:
65 wxClientDataContainer();
16d38102 66 virtual ~wxClientDataContainer();
88a9f974 67
88a9f974
RD
68 void SetClientObject( wxClientData *data ) { DoSetClientObject(data); }
69 wxClientData *GetClientObject() const { return DoGetClientObject(); }
70
71 void SetClientData( void *data ) { DoSetClientData(data); }
72 void *GetClientData() const { return DoGetClientData(); }
73
74protected:
16d38102
RD
75 // The user data: either an object which will be deleted by the container
76 // when it's deleted or some raw pointer which we do nothing with - only
77 // one type of data can be used with the given window (i.e. you cannot set
b88c44e7 78 // the void data and then associate the container with wxClientData or vice
16d38102 79 // versa)
88a9f974
RD
80 union
81 {
82 wxClientData *m_clientObject;
83 void *m_clientData;
84 };
85
86 // client data accessors
87 virtual void DoSetClientObject( wxClientData *data );
88 virtual wxClientData *DoGetClientObject() const;
89
90 virtual void DoSetClientData( void *data );
91 virtual void *DoGetClientData() const;
92
93 // what kind of data do we have?
94 wxClientDataType m_clientDataType;
95
96};
2aab8f16 97
88a9f974
RD
98// ----------------------------------------------------------------------------
99#endif
100