2001-10-09 22:50:33 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/clntdata.h
|
|
|
|
// Purpose: A mixin class for holding a wxClientData or void pointer
|
|
|
|
// Author: Robin Dunn
|
|
|
|
// Modified by:
|
|
|
|
// Created: 9-Oct-2001
|
2004-05-23 14:56:36 +00:00
|
|
|
// Copyright: (c) wxWidgets team
|
2004-05-23 20:53:33 +00:00
|
|
|
// Licence: wxWindows licence
|
2001-10-09 22:50:33 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_CLNTDATAH__
|
|
|
|
#define _WX_CLNTDATAH__
|
|
|
|
|
|
|
|
#include "wx/defs.h"
|
2001-10-09 23:09:41 +00:00
|
|
|
#include "wx/string.h"
|
2005-06-26 15:48:02 +00:00
|
|
|
#include "wx/hashmap.h"
|
|
|
|
|
|
|
|
typedef int (*wxShadowObjectMethod)(void*, void*);
|
2005-07-14 15:14:04 +00:00
|
|
|
WX_DECLARE_STRING_HASH_MAP_WITH_DECL(
|
|
|
|
wxShadowObjectMethod,
|
|
|
|
wxShadowObjectMethods,
|
|
|
|
class WXDLLIMPEXP_BASE
|
2006-01-18 16:45:41 +00:00
|
|
|
);
|
2005-07-14 15:14:04 +00:00
|
|
|
WX_DECLARE_STRING_HASH_MAP_WITH_DECL(
|
|
|
|
void *,
|
|
|
|
wxShadowObjectFields,
|
|
|
|
class WXDLLIMPEXP_BASE
|
2006-01-18 16:45:41 +00:00
|
|
|
);
|
2005-06-26 15:48:02 +00:00
|
|
|
|
|
|
|
class WXDLLIMPEXP_BASE wxShadowObject
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
wxShadowObject() { }
|
2005-09-25 20:23:30 +00:00
|
|
|
|
2005-06-26 15:48:02 +00:00
|
|
|
void AddMethod( const wxString &name, wxShadowObjectMethod method )
|
2005-09-25 20:23:30 +00:00
|
|
|
{
|
2005-06-26 15:48:02 +00:00
|
|
|
wxShadowObjectMethods::iterator it = m_methods.find( name );
|
|
|
|
if (it == m_methods.end())
|
|
|
|
m_methods[ name ] = method;
|
|
|
|
else
|
|
|
|
it->second = method;
|
|
|
|
}
|
2005-09-25 20:23:30 +00:00
|
|
|
|
2005-06-26 15:48:02 +00:00
|
|
|
bool InvokeMethod( const wxString &name, void* window, void* param, int* returnValue )
|
2005-09-25 20:23:30 +00:00
|
|
|
{
|
2005-06-26 15:48:02 +00:00
|
|
|
wxShadowObjectMethods::iterator it = m_methods.find( name );
|
|
|
|
if (it == m_methods.end())
|
|
|
|
return false;
|
|
|
|
wxShadowObjectMethod method = it->second;
|
2018-05-29 07:54:19 +00:00
|
|
|
const int ret = (*method)(window, param);
|
2005-06-26 15:48:02 +00:00
|
|
|
if (returnValue)
|
|
|
|
*returnValue = ret;
|
|
|
|
return true;
|
|
|
|
}
|
2005-09-25 20:23:30 +00:00
|
|
|
|
2005-06-26 15:48:02 +00:00
|
|
|
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;
|
|
|
|
}
|
2005-09-25 20:23:30 +00:00
|
|
|
|
2005-06-26 15:48:02 +00:00
|
|
|
void SetField( const wxString &name, void* value )
|
|
|
|
{
|
|
|
|
wxShadowObjectFields::iterator it = m_fields.find( name );
|
|
|
|
if (it == m_fields.end())
|
|
|
|
return;
|
|
|
|
it->second = value;
|
|
|
|
}
|
2005-09-25 20:23:30 +00:00
|
|
|
|
2005-06-26 15:48:02 +00:00
|
|
|
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;
|
|
|
|
}
|
2005-09-25 20:23:30 +00:00
|
|
|
|
2005-06-26 15:48:02 +00:00
|
|
|
private:
|
|
|
|
wxShadowObjectMethods m_methods;
|
|
|
|
wxShadowObjectFields m_fields;
|
|
|
|
};
|
2001-10-09 22:50:33 +00:00
|
|
|
|
2005-07-22 20:21:14 +00:00
|
|
|
|
2001-10-09 22:50:33 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// what kind of client data do we have?
|
|
|
|
enum wxClientDataType
|
|
|
|
{
|
|
|
|
wxClientData_None, // we don't know yet because we don't have it at all
|
|
|
|
wxClientData_Object, // our client data is typed and we own it
|
|
|
|
wxClientData_Void // client data is untyped and we don't own it
|
|
|
|
};
|
|
|
|
|
2004-07-15 16:24:24 +00:00
|
|
|
class WXDLLIMPEXP_BASE wxClientData
|
2001-10-09 22:50:33 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
wxClientData() { }
|
|
|
|
virtual ~wxClientData() { }
|
|
|
|
};
|
|
|
|
|
2004-07-15 16:24:24 +00:00
|
|
|
class WXDLLIMPEXP_BASE wxStringClientData : public wxClientData
|
2001-10-09 22:50:33 +00:00
|
|
|
{
|
|
|
|
public:
|
2002-05-07 21:58:27 +00:00
|
|
|
wxStringClientData() : m_data() { }
|
2001-10-09 22:50:33 +00:00
|
|
|
wxStringClientData( const wxString &data ) : m_data(data) { }
|
|
|
|
void SetData( const wxString &data ) { m_data = data; }
|
|
|
|
const wxString& GetData() const { return m_data; }
|
|
|
|
|
|
|
|
private:
|
|
|
|
wxString m_data;
|
|
|
|
};
|
|
|
|
|
2001-10-09 23:09:41 +00:00
|
|
|
// 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
|
2003-06-26 13:15:12 +00:00
|
|
|
// object in which case it is managed by the container (i.e. it will delete
|
2001-10-09 23:09:41 +00:00
|
|
|
// the data when it's destroyed) or an untyped pointer which won't be deleted
|
2001-10-21 03:56:07 +00:00
|
|
|
// by the container - but not both of them
|
|
|
|
//
|
|
|
|
// NOTE: This functionality is currently duplicated in wxEvtHandler in order
|
2003-06-26 13:15:12 +00:00
|
|
|
// to avoid having more than one vtable in that class hierarchy.
|
2001-10-09 23:09:41 +00:00
|
|
|
|
2004-07-15 16:24:24 +00:00
|
|
|
class WXDLLIMPEXP_BASE wxClientDataContainer
|
2001-10-09 22:50:33 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
wxClientDataContainer();
|
2001-10-09 23:09:41 +00:00
|
|
|
virtual ~wxClientDataContainer();
|
2001-10-09 22:50:33 +00:00
|
|
|
|
|
|
|
void SetClientObject( wxClientData *data ) { DoSetClientObject(data); }
|
|
|
|
wxClientData *GetClientObject() const { return DoGetClientObject(); }
|
|
|
|
|
|
|
|
void SetClientData( void *data ) { DoSetClientData(data); }
|
|
|
|
void *GetClientData() const { return DoGetClientData(); }
|
|
|
|
|
|
|
|
protected:
|
2001-10-09 23:09:41 +00:00
|
|
|
// The user data: either an object which will be deleted by the container
|
2003-06-26 13:15:12 +00:00
|
|
|
// 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
|
2001-10-12 03:18:35 +00:00
|
|
|
// the void data and then associate the container with wxClientData or vice
|
2003-06-26 13:15:12 +00:00
|
|
|
// versa.
|
2001-10-09 22:50:33 +00:00
|
|
|
union
|
|
|
|
{
|
|
|
|
wxClientData *m_clientObject;
|
|
|
|
void *m_clientData;
|
|
|
|
};
|
|
|
|
|
|
|
|
// client data accessors
|
|
|
|
virtual void DoSetClientObject( wxClientData *data );
|
|
|
|
virtual wxClientData *DoGetClientObject() const;
|
|
|
|
|
|
|
|
virtual void DoSetClientData( void *data );
|
|
|
|
virtual void *DoGetClientData() const;
|
|
|
|
|
|
|
|
// what kind of data do we have?
|
|
|
|
wxClientDataType m_clientDataType;
|
|
|
|
|
|
|
|
};
|
2001-10-21 03:56:07 +00:00
|
|
|
|
2005-09-25 20:23:30 +00:00
|
|
|
#endif // _WX_CLNTDATAH__
|
2001-10-09 22:50:33 +00:00
|
|
|
|