1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: wxObject class, plus run-time type information macros
4 // Author: Julian Smart
8 // Copyright: (c) Julian Smart and Markus Holzem
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
16 #pragma interface "object.h"
20 #include "wx/memory.h"
22 class WXDLLEXPORT wxObject
;
24 #if wxUSE_DYNAMIC_CLASSES
26 // #ifdef __GNUWIN32__
35 class WXDLLEXPORT wxClassInfo
;
36 class WXDLLEXPORT wxInputStream
;
37 class WXDLLEXPORT wxOutputStream
;
38 class WXDLLEXPORT wxObjectInputStream
;
39 class WXDLLEXPORT wxObjectOutputStream
;
40 class WXDLLEXPORT wxHashTable
;
41 class WXDLLEXPORT wxObject_Serialize
;
43 #if wxUSE_STD_IOSTREAM && (defined(__WXDEBUG__) || wxUSE_DEBUG_CONTEXT)
44 #include "wx/ioswrap.h"
48 * Dynamic object system declarations
51 typedef wxObject
* (*wxObjectConstructorFn
) (void);
53 class WXDLLEXPORT wxClassInfo
56 wxClassInfo(wxChar
*cName
, wxChar
*baseName1
, wxChar
*baseName2
, int sz
, wxObjectConstructorFn fn
);
58 wxObject
*CreateObject(void);
60 inline wxChar
*GetClassName(void) const { return m_className
; }
61 inline wxChar
*GetBaseClassName1(void) const { return m_baseClassName1
; }
62 inline wxChar
*GetBaseClassName2(void) const { return m_baseClassName2
; }
63 inline wxClassInfo
* GetBaseClass1() const { return m_baseInfo1
; }
64 inline wxClassInfo
* GetBaseClass2() const { return m_baseInfo2
; }
65 inline int GetSize(void) const { return m_objectSize
; }
66 inline wxObjectConstructorFn
GetConstructor() const { return m_objectConstructor
; }
67 static inline wxClassInfo
* GetFirst() { return sm_first
; }
68 inline wxClassInfo
* GetNext() const { return m_next
; }
69 bool IsKindOf(wxClassInfo
*info
) const;
71 static wxClassInfo
*FindClass(wxChar
*c
);
73 // Initializes parent pointers and hash table for fast searching.
74 static void InitializeClasses(void);
76 // Cleans up hash table used for fast searching.
77 static void CleanUpClasses(void);
81 wxChar
* m_baseClassName1
;
82 wxChar
* m_baseClassName2
;
84 wxObjectConstructorFn m_objectConstructor
;
86 // Pointers to base wxClassInfos: set in InitializeClasses
87 // called from wx_main.cc
88 wxClassInfo
* m_baseInfo1
;
89 wxClassInfo
* m_baseInfo2
;
91 static wxClassInfo
* sm_first
;
94 static wxHashTable
* sm_classTable
;
97 WXDLLEXPORT wxObject
* wxCreateDynamicObject(const wxChar
*name
);
100 WXDLLEXPORT wxObject
* wxCreateStoredObject( wxInputStream
& stream
);
103 #define DECLARE_DYNAMIC_CLASS(name) \
105 static wxClassInfo sm_class##name;\
106 wxClassInfo *GetClassInfo() const \
107 { return &name::sm_class##name; }
109 #define DECLARE_ABSTRACT_CLASS(name) DECLARE_DYNAMIC_CLASS(name)
110 #define DECLARE_CLASS(name) DECLARE_DYNAMIC_CLASS(name)
113 ////// for concrete classes
116 // Single inheritance with one base class
117 #define IMPLEMENT_DYNAMIC_CLASS(name, basename) \
118 wxObject* WXDLLEXPORT_CTORFN wxConstructorFor##name(void) \
119 { return new name; }\
120 wxClassInfo name::sm_class##name((wxChar *) wxT(#name), (wxChar *) wxT(#basename), (wxChar *) NULL, (int) sizeof(name), (wxObjectConstructorFn) wxConstructorFor##name);
122 // Multiple inheritance with two base classes
123 #define IMPLEMENT_DYNAMIC_CLASS2(name, basename1, basename2) \
124 wxObject* WXDLLEXPORT_CTORFN wxConstructorFor##name(void) \
125 { return new name; }\
126 wxClassInfo name::sm_class##name((wxChar *) wxT(#name), (wxChar *) wxT(#basename1), (wxChar *) wxT(#basename2), (int) sizeof(name), (wxObjectConstructorFn) wxConstructorFor##name);
129 ////// for abstract classes
132 // Single inheritance with one base class
133 #define IMPLEMENT_ABSTRACT_CLASS(name, basename) \
134 wxClassInfo name::sm_class##name((wxChar *) wxT(#name), (wxChar *) wxT(#basename), \
135 (wxChar *) NULL, (int) sizeof(name), (wxObjectConstructorFn) NULL);
137 // Multiple inheritance with two base classes
138 #define IMPLEMENT_ABSTRACT_CLASS2(name, basename1, basename2) \
139 wxClassInfo name::sm_class##name((wxChar *) wxT(#name), (wxChar *) wxT(#basename1), \
140 (wxChar *) wxT(#basename2), (int) sizeof(name), (wxObjectConstructorFn) NULL);
142 #define IMPLEMENT_CLASS IMPLEMENT_ABSTRACT_CLASS
143 #define IMPLEMENT_CLASS2 IMPLEMENT_ABSTRACT_CLASS2
145 #define CLASSINFO(name) (&name::sm_class##name)
147 #else // !wxUSE_DYNAMIC_CLASSES
149 // No dynamic class system: so stub out the macros
150 #define DECLARE_DYNAMIC_CLASS(name)
151 #define DECLARE_ABSTRACT_CLASS(name)
152 #define DECLARE_CLASS(name)
153 #define IMPLEMENT_DYNAMIC_CLASS(name, basename)
154 #define IMPLEMENT_DYNAMIC_CLASS2(name, basename1, basename2)
155 #define IMPLEMENT_ABSTRACT_CLASS(name, basename)
156 #define IMPLEMENT_ABSTRACT_CLASS2(name, basename1, basename2)
157 #define IMPLEMENT_CLASS IMPLEMENT_ABSTRACT_CLASS
158 #define IMPLEMENT_CLASS2 IMPLEMENT_ABSTRACT_CLASS2
160 #endif // wxUSE_DYNAMIC_CLASSES/!wxUSE_DYNAMIC_CLASSES
162 #define wxIS_KIND_OF(obj, className) obj->IsKindOf(&className::sm_class##className)
164 // Just seems a bit nicer-looking (pretend it's not a macro)
165 #define wxIsKindOf(obj, className) obj->IsKindOf(&className::sm_class##className)
167 // to be replaced by dynamic_cast<> in the future
168 #define wxDynamicCast(obj, className) \
169 ((obj) && ((obj)->IsKindOf(&className::sm_class##className)) \
170 ? (className *)(obj) \
173 #define wxConstCast(obj, className) ((className *)(obj))
176 inline void wxCheckCast(void *ptr
)
178 wxASSERT_MSG( ptr
, _T("wxStaticCast() used incorrectly") );
181 #define wxStaticCast(obj, className) \
182 (wxCheckCast(wxDynamicCast(obj, className)), ((className *)(obj)))
185 #define wxStaticCast(obj, className) ((className *)(obj))
186 #endif // Debug/!Debug
188 // Unfortunately Borland seems to need this include.
191 #include <iostream.h>
197 class WXDLLEXPORT wxObjectRefData
;
199 class WXDLLEXPORT wxObject
203 // This is equivalent to using the macro DECLARE_ABSTRACT_CLASS
204 static wxClassInfo sm_classwxObject
;
207 virtual ~wxObject(void);
209 virtual wxClassInfo
*GetClassInfo(void) const { return &sm_classwxObject
; }
210 wxObject
*Clone(void) const;
211 virtual void CopyObject(wxObject
& object_dest
) const;
213 bool IsKindOf(wxClassInfo
*info
) const;
215 #if defined(__WXDEBUG__) && wxUSE_MEMORY_TRACING
216 void * operator new (size_t size
, wxChar
* fileName
= NULL
, int lineNum
= 0);
218 #if defined(__VISAGECPP__)
220 void operator delete (void * buf
,const char * _fname
, size_t _line
);
221 #endif //__DEBUG_ALLOC__
223 void operator delete (void * buf
);
225 // defined(__VISAGECPP__)
228 #if defined(__VISUALC__) && (__VISUALC__ >= 1200)
229 void operator delete(void *buf
, wxChar
*, int);
232 // Causes problems for VC++
233 #if wxUSE_ARRAY_MEMORY_OPERATORS && !defined(__VISUALC__) && !defined( __MWERKS__)
234 void * operator new[] (size_t size
, wxChar
* fileName
= NULL
, int lineNum
= 0);
235 void operator delete[] (void * buf
);
239 void * operator new[] (size_t size
, wxChar
* fileName
, int lineNum
= 0);
240 void * operator new[] (size_t size
) { return operator new[] ( size
, NULL
, 0 ) ; }
241 void operator delete[] (void * buf
);
244 #endif // Debug & memory tracing
246 #if wxUSE_STD_IOSTREAM && (defined(__WXDEBUG__) || wxUSE_DEBUG_CONTEXT)
247 virtual void Dump(ostream
& str
);
251 virtual void StoreObject( wxObjectOutputStream
&stream
);
252 virtual void LoadObject( wxObjectInputStream
&stream
);
255 // make a 'clone' of the object
256 void Ref(const wxObject
& clone
);
258 // destroy a reference
261 inline wxObjectRefData
*GetRefData(void) const { return m_refData
; }
262 inline void SetRefData(wxObjectRefData
*data
) { m_refData
= data
; }
265 #if defined(__WXDEBUG__) && defined(__VISAGECPP__)
268 static int Nid
; // total number of objects and serial counter
269 int id
; // serial number for current object
270 #endif // __WXDEBUG__
273 wxObjectRefData
* m_refData
;
275 wxObject_Serialize
* m_serialObj
;
283 class WXDLLEXPORT wxObjectRefData
{
285 friend class wxObject
;
288 wxObjectRefData(void);
289 virtual ~wxObjectRefData(void);
291 inline int GetRefCount(void) const { return m_count
; }
298 #define WXDEBUG_NEW new(__TFILE__,__LINE__)
301 #define WXDEBUG_NEW new
304 // Redefine new to be the debugging version. This doesn't
305 // work with all compilers, in which case you need to
306 // use WXDEBUG_NEW explicitly if you wish to use the debugging version.
308 #if defined(__WXDEBUG__) && wxUSE_GLOBAL_MEMORY_OPERATORS && wxUSE_DEBUG_NEW_ALWAYS
309 #define new new(__TFILE__,__LINE__)