// Modified by:
// Created: 9-Oct-2001
// RCS-ID: $Id$
-// Copyright: (c) wxWindows team
+// Copyright: (c) wxWidgets team
// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
#ifndef _WX_CLNTDATAH__
#define _WX_CLNTDATAH__
-#if defined(__GNUG__) && !defined(__APPLE__)
+#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
#pragma interface "clntdata.h"
#endif
#include "wx/defs.h"
#include "wx/string.h"
+#include "wx/hashmap.h"
+
+typedef int (*wxShadowObjectMethod)(void*, void*);
+WX_DECLARE_STRING_HASH_MAP( wxShadowObjectMethod, wxShadowObjectMethods );
+WX_DECLARE_STRING_HASH_MAP( void*, wxShadowObjectFields );
+
+class WXDLLIMPEXP_BASE wxShadowObject
+{
+public:
+ wxShadowObject() { }
+
+ void AddMethod( const wxString &name, wxShadowObjectMethod method )
+ {
+ wxShadowObjectMethods::iterator it = m_methods.find( name );
+ if (it == m_methods.end())
+ m_methods[ name ] = method;
+ else
+ it->second = method;
+ }
+
+ bool InvokeMethod( const wxString &name, void* window, void* param, int* returnValue )
+ {
+ wxShadowObjectMethods::iterator it = m_methods.find( name );
+ if (it == m_methods.end())
+ return false;
+ wxShadowObjectMethod method = it->second;
+ int ret = (*method)(window, param);
+ if (returnValue)
+ *returnValue = ret;
+ return true;
+ }
+
+ void AddField( const wxString &name, void* initialValue = NULL )
+ {
+ wxShadowObjectFields::iterator it = m_fields.find( name );
+ if (it == m_fields.end())
+ m_fields[ name ] = initialValue;
+ else
+ it->second = initialValue;
+ }
+
+ void SetField( const wxString &name, void* value )
+ {
+ wxShadowObjectFields::iterator it = m_fields.find( name );
+ if (it == m_fields.end())
+ return;
+ it->second = value;
+ }
+
+ void* GetField( const wxString &name, void *defaultValue = NULL )
+ {
+ wxShadowObjectFields::iterator it = m_fields.find( name );
+ if (it == m_fields.end())
+ return defaultValue;
+ return it->second;
+ }
+
+private:
+ wxShadowObjectMethods m_methods;
+ wxShadowObjectFields m_fields;
+};
// ----------------------------------------------------------------------------
wxClientData_Void // client data is untyped and we don't own it
};
-class WXDLLEXPORT wxClientData
+class WXDLLIMPEXP_BASE wxClientData
{
public:
wxClientData() { }
virtual ~wxClientData() { }
};
-class WXDLLEXPORT wxStringClientData : public wxClientData
+class WXDLLIMPEXP_BASE wxStringClientData : public wxClientData
{
public:
wxStringClientData() : m_data() { }
wxString m_data;
};
-
-
// This class is a mixin that provides storage and management of "client
// data." The client data stored can either be a pointer to a wxClientData
-// object in which case it is managed by the container (i.e. it will delete
+// object in which case it is managed by the container (i.e. it will delete
// the data when it's destroyed) or an untyped pointer which won't be deleted
// by the container - but not both of them
//
// NOTE: This functionality is currently duplicated in wxEvtHandler in order
-// to avoid having more than one vtable in that class heirachy.
+// to avoid having more than one vtable in that class hierarchy.
-class WXDLLEXPORT wxClientDataContainer
+class WXDLLIMPEXP_BASE wxClientDataContainer
{
public:
wxClientDataContainer();
protected:
// The user data: either an object which will be deleted by the container
- // when it's deleted or some raw pointer which we do nothing with - only
- // one type of data can be used with the given window (i.e. you cannot set
+ // when it's deleted or some raw pointer which we do nothing with. Only
+ // one type of data can be used with the given window, i.e. you cannot set
// the void data and then associate the container with wxClientData or vice
- // versa)
+ // versa.
union
{
wxClientData *m_clientObject;
#include <wx/vector.h>
-struct WXDLLEXPORT wxClientDataDictionaryPair
+struct WXDLLIMPEXP_BASE wxClientDataDictionaryPair
{
wxClientDataDictionaryPair( size_t idx ) : index( idx ), data( 0 ) { }
// this class is used internally to maintain the association between items
// of (some subclasses of) wxControlWithItems and their client data
-// NOTE: this class does not keep track if it contains
-// wxClientData or void*, the client must ensure that
+// NOTE: this class does not keep track of whether it contains
+// wxClientData or void*. The client must ensure that
// it does not contain a mix of the two, and that
// DestroyData is called if it contains wxClientData
-class WXDLLEXPORT wxClientDataDictionary
+class WXDLLIMPEXP_BASE wxClientDataDictionary
{
public:
- wxClientDataDictionary() {};
+ wxClientDataDictionary() {}
// deletes all the data
void DestroyData()