]>
git.saurik.com Git - wxWidgets.git/blob - src/common/object.cpp
   1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     wxObject implementation 
   4 // Author:      Julian Smart 
   5 // Modified by: Ron Lee 
   8 // Copyright:   (c) 1998 Julian Smart and Markus Holzem 
   9 //              (c) 2001 Ron Lee <ron@debian.org> 
  10 // Licence:     wxWindows license 
  11 ///////////////////////////////////////////////////////////////////////////// 
  14 #pragma implementation "object.h" 
  17     // For compilers that support precompilation, includes "wx.h". 
  19 #include "wx/wxprec.h" 
  32 #if (defined(__WXDEBUG__) && wxUSE_MEMORY_TRACING) || wxUSE_DEBUG_CONTEXT 
  33 #include "wx/memory.h" 
  36 #if defined(__WXDEBUG__) || wxUSE_DEBUG_CONTEXT 
  38 #include "wx/ioswrap.h" 
  40 #if defined(__VISAGECPP__) 
  41 #define DEBUG_PRINTF(NAME) { static int raz=0; \ 
  42  printf( #NAME " %i\n",raz); fflush(stdout); raz++; } 
  44 #define DEBUG_PRINTF(NAME) 
  50 wxClassInfo 
wxObject::sm_classwxObject( wxT("wxObject"), 0, 0, 
  51                                         (int) sizeof(wxObject
), 
  52                                         (wxObjectConstructorFn
) 0 ); 
  53 wxClassInfo
* wxClassInfo::sm_first 
= 0; 
  54 wxHashTable
* wxClassInfo::sm_classTable 
= 0; 
  56     // These are here so we can avoid 'always true/false' warnings 
  57     // by referring to these instead of TRUE/FALSE 
  59 const bool wxTrue 
= TRUE
; 
  60 const bool wxFalse 
= FALSE
; 
  62     // Is this object a kind of (a subclass of) 'info'? 
  63     // E.g. is wxWindow a kind of wxObject? 
  64     // Go from this class to superclass, taking into account 
  65     // two possible base classes. 
  67 bool wxObject::IsKindOf(wxClassInfo 
*info
) const 
  69     wxClassInfo 
*thisInfo 
= GetClassInfo(); 
  70     return (thisInfo
) ? thisInfo
->IsKindOf(info
) : FALSE 
; 
  73 #if wxUSE_STD_IOSTREAM && (defined(__WXDEBUG__) || wxUSE_DEBUG_CONTEXT) 
  74 void wxObject::Dump(wxSTD ostream
& str
) 
  76     if (GetClassInfo() && GetClassInfo()->GetClassName()) 
  77         str 
<< GetClassInfo()->GetClassName(); 
  79         str 
<< "unknown object class"; 
  83 #if defined(__WXDEBUG__) && wxUSE_MEMORY_TRACING 
  89 void *wxObject::operator new (size_t size
, wxChar 
*fileName
, int lineNum
) 
  91     return wxDebugAlloc(size
, fileName
, lineNum
, TRUE
); 
  95 void wxObject::operator delete (void *buf
) 
 100 void wxObject::operator delete (void *buf
, const char *_fname
, size_t _line
) 
 108 #if defined(__VISUALC__) && (__VISUALC__ >= 1200) 
 109 void wxObject::operator delete(void *pData
, wxChar 
*WXUNUSED(fileName
), int WXUNUSED(lineNum
)) 
 111     ::operator delete(pData
); 
 115     // Cause problems for VC++ - crashes 
 117 #if (!defined(__VISUALC__) && wxUSE_ARRAY_MEMORY_OPERATORS ) || defined(__MWERKS__) 
 118 void *wxObject::operator new[] (size_t size
, wxChar 
*fileName
, int lineNum
) 
 120     return wxDebugAlloc(size
, fileName
, lineNum
, TRUE
, TRUE
); 
 123 void wxObject::operator delete[] (void *buf
) 
 125     wxDebugFree(buf
, TRUE
); 
 129 #endif  // __WXDEBUG__  && wxUSE_MEMORY_TRACING 
 132 // ---------------------------------------------------------------------------- 
 134 // ---------------------------------------------------------------------------- 
 136 wxClassInfo 
*wxClassInfo::FindClass(const wxChar 
*className
) 
 138     for(wxClassInfo 
*info 
= sm_first
; info 
; info 
= info
->m_next
) 
 139         if( wxStrcmp(info
->GetClassName(), className
) == 0 ) 
 145     // Set pointers to base class(es) to speed up IsKindOf 
 147 void wxClassInfo::InitializeClasses() 
 149     // using IMPLEMENT_DYNAMIC_CLASS() macro twice (which may happen if you 
 150     // link any object module twice mistakenly) will break this function 
 151     // because it will enter an infinite loop and eventually die with "out of 
 152     // memory" - as this is quite hard to detect if you're unaware of this, 
 153     // try to do some checks here 
 156     static const size_t nMaxClasses 
= 10000;    // more than we'll ever have 
 160     wxClassInfo::sm_classTable 
= new wxHashTable(wxKEY_STRING
); 
 162         // Index all class infos by their class name 
 165     for(info 
= sm_first
; info
; info 
= info
->m_next
) 
 167         if (info
->m_className
) 
 169             wxASSERT_MSG( ++nClass 
< nMaxClasses
, 
 170                           _T("an infinite loop detected - have you used IMPLEMENT_DYNAMIC_CLASS() twice (may be by linking some object module(s) twice)?") ); 
 171             sm_classTable
->Put(info
->m_className
, (wxObject 
*)info
); 
 175         // Set base pointers for each wxClassInfo 
 177     for(info 
= sm_first
; info
; info 
= info
->m_next
) 
 179         if (info
->GetBaseClassName1()) 
 180             info
->m_baseInfo1 
= (wxClassInfo 
*)sm_classTable
->Get(info
->GetBaseClassName1()); 
 181         if (info
->GetBaseClassName2()) 
 182             info
->m_baseInfo2 
= (wxClassInfo 
*)sm_classTable
->Get(info
->GetBaseClassName2()); 
 186 void wxClassInfo::CleanUpClasses() 
 188     delete wxClassInfo::sm_classTable
; 
 189     wxClassInfo::sm_classTable 
= 0; 
 193 wxObject 
*wxCreateDynamicObject(const wxChar 
*name
) 
 195 #if defined(__WXDEBUG__) || wxUSE_DEBUG_CONTEXT 
 196  DEBUG_PRINTF(wxObject 
*wxCreateDynamicObject
) 
 199     if (wxClassInfo::sm_classTable
) 
 201         wxClassInfo 
*info 
= (wxClassInfo 
*)wxClassInfo::sm_classTable
->Get(name
); 
 202         return info 
!= 0 ? info
->CreateObject() : 0; 
 206         for(wxClassInfo 
*info 
= wxClassInfo::sm_first
; info
; info 
= info
->m_next
) 
 207             if (info
->m_className 
&& wxStrcmp(info
->m_className
, name
) == 0) 
 208                 return info
->CreateObject(); 
 214 // ---------------------------------------------------------------------------- 
 216 // ---------------------------------------------------------------------------- 
 218 void wxObject::Ref(const wxObject
& clone
) 
 220 #if defined(__WXDEBUG__) || wxUSE_DEBUG_CONTEXT 
 221  DEBUG_PRINTF(wxObject::Ref
) 
 224     // delete reference to old data 
 227     // reference new data 
 228     if( clone
.m_refData 
) 
 230         m_refData 
= clone
.m_refData
; 
 231         ++(m_refData
->m_count
); 
 235 void wxObject::UnRef() 
 239         wxASSERT_MSG( m_refData
->m_count 
> 0, _T("invalid ref data count") ); 
 241         if ( !--m_refData
->m_count 
) 
 248 #if defined(__DARWIN__) && defined(DYLIB_INIT) 
 251     void __initialize_Cplusplus(void); 
 252     void wxWindowsDylibInit(void); 
 255     // Dynamic shared library (dylib) initialization routine 
 256     //   required to initialize static C++ objects bacause of lazy dynamic linking 
 257     //   http://developer.apple.com/techpubs/macosx/Essentials/ 
 258     //          SystemOverview/Frameworks/Dynamic_Shared_Libraries.html 
 260 void wxWindowsDylibInit() 
 262     // The function __initialize_Cplusplus() must be called from the shared 
 263     // library initialization routine to cause the static C++ objects in 
 264     // the library to be initialized (reference number 2441683). 
 266     __initialize_Cplusplus();