, m_baseInfo1(0)
, m_baseInfo2(0)
, m_next(sm_first)
- { sm_first = this; }
+ { sm_first = this; }
+
+ ~wxClassInfo()
+ {
+ if (sm_first == this)
+ {
+ sm_first = m_next;
+ }
+ else
+ {
+ wxClassInfo * info = sm_first;
+ while (info)
+ {
+ if (info->m_next == this)
+ {
+ info->m_next = m_next;
+ break;
+ }
+ info = info->m_next;
+ }
+ }
+ }
wxObject *CreateObject() { return m_objectConstructor ? (*m_objectConstructor)() : 0; }
private:
// InitializeClasses() helper
static wxClassInfo *GetBaseByName(const wxChar *name);
+
+ DECLARE_NO_COPY_CLASS(wxClassInfo)
};
WXDLLEXPORT wxObject *wxCreateDynamicObject(const wxChar *name);
#endif
// Only VC++ 6.0 and CodeWarrior compilers get overloaded delete that matches new
-#if ( defined(__VISUALC__) && (__VISUALC__ >= 1200) ) || defined(__MWERKS__)
+#if ( defined(__VISUALC__) && (__VISUALC__ >= 1200) ) || (defined(__MWERKS__) && (__MWERKS__ >= 0x2400))
#define _WX_WANT_DELETE_VOID_WXCHAR_INT
#endif
class WXDLLEXPORT wxObject
{
-DECLARE_ABSTRACT_CLASS(wxObject)
+ DECLARE_ABSTRACT_CLASS(wxObject)
+private:
+ void InitFrom(const wxObject& other);
+
public:
wxObject() { m_refData = NULL; }
virtual ~wxObject() { UnRef(); }
+
+ wxObject(const wxObject& other)
+ {
+ InitFrom(other);
+ }
+
+ wxObject& operator=(const wxObject& other)
+ {
+ if ( this != &other )
+ {
+ UnRef();
+ InitFrom(other);
+ }
+ return *this;
+ }
bool IsKindOf(wxClassInfo *info) const;
// Turn on the correct set of new and delete operators
#ifdef _WX_WANT_NEW_SIZET_WXCHAR_INT
- void *operator new ( size_t size, wxChar *fileName = NULL, int lineNum = 0 );
+ void *operator new ( size_t size, const wxChar *fileName = NULL, int lineNum = 0 );
#endif
#ifdef _WX_WANT_DELETE_VOID
#endif
#ifdef _WX_WANT_DELETE_VOID_WXCHAR_INT
- void operator delete ( void *buf, wxChar*, int );
+ void operator delete ( void *buf, const wxChar*, int );
#endif
#ifdef _WX_WANT_ARRAY_NEW_SIZET_WXCHAR_INT
- void *operator new[] ( size_t size, wxChar *fileName = NULL, int lineNum = 0 );
+ void *operator new[] ( size_t size, const wxChar *fileName = NULL, int lineNum = 0 );
#endif
#ifdef _WX_WANT_ARRAY_DELETE_VOID
#endif
#ifdef _WX_WANT_ARRAY_DELETE_VOID_WXCHAR_INT
- void operator delete[] (void* buf, wxChar*, int );
+ void operator delete[] (void* buf, const wxChar*, int );
#endif