X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/afb7489128719ac8999b037d49a0c28636d59558..ec5d85fbd58bf6ef774e3d93b9e38d9f90b42d40:/src/common/object.cpp?ds=sidebyside diff --git a/src/common/object.cpp b/src/common/object.cpp index 8c1f4febb7..5b65936689 100644 --- a/src/common/object.cpp +++ b/src/common/object.cpp @@ -45,7 +45,7 @@ #endif #if !USE_SHARED_LIBRARY -wxClassInfo wxObject::sm_classwxObject((char *) "wxObject", (char *) NULL, (char *) NULL, (int ) sizeof(wxObject), (wxObjectConstructorFn) NULL); +wxClassInfo wxObject::sm_classwxObject((wxChar *) _T("wxObject"), (wxChar *) NULL, (wxChar *) NULL, (int ) sizeof(wxObject), (wxObjectConstructorFn) NULL); wxClassInfo* wxClassInfo::sm_first = (wxClassInfo *) NULL; wxHashTable* wxClassInfo::sm_classTable = (wxHashTable*) NULL; #endif @@ -87,6 +87,11 @@ bool wxObject::IsKindOf(wxClassInfo *info) const return FALSE; } +wxObject *wxObject::Clone() const +{ + return GetClassInfo()->CreateObject(); +} + #if defined(__WXDEBUG__) || wxUSE_DEBUG_CONTEXT void wxObject::Dump(ostream& str) { @@ -103,7 +108,7 @@ void wxObject::Dump(ostream& str) #undef new #endif -void *wxObject::operator new (size_t size, char * fileName, int lineNum) +void *wxObject::operator new (size_t size, wxChar * fileName, int lineNum) { return wxDebugAlloc(size, fileName, lineNum, TRUE); } @@ -123,7 +128,7 @@ void wxObject::operator delete(void* pData, char* /* fileName */, int /* lineNum // Cause problems for VC++ - crashes #if !defined(__VISUALC__) && wxUSE_ARRAY_MEMORY_OPERATORS -void * wxObject::operator new[] (size_t size, char * fileName, int lineNum) +void * wxObject::operator new[] (size_t size, wxChar * fileName, int lineNum) { return wxDebugAlloc(size, fileName, lineNum, TRUE, TRUE); } @@ -140,7 +145,7 @@ void wxObject::operator delete[] (void * buf) * Class info: provides run-time class type information. */ -wxClassInfo::wxClassInfo(char *cName, char *baseName1, char *baseName2, int sz, wxObjectConstructorFn constr) +wxClassInfo::wxClassInfo(wxChar *cName, wxChar *baseName1, wxChar *baseName2, int sz, wxObjectConstructorFn constr) { m_className = cName; m_baseClassName1 = baseName1; @@ -164,12 +169,12 @@ wxObject *wxClassInfo::CreateObject() return (wxObject *) NULL; } -wxClassInfo *wxClassInfo::FindClass(char *c) +wxClassInfo *wxClassInfo::FindClass(wxChar *c) { wxClassInfo *p = sm_first; while (p) { - if (p && p->GetClassName() && strcmp(p->GetClassName(), c) == 0) + if (p && p->GetClassName() && wxStrcmp(p->GetClassName(), c) == 0) return p; p = p->m_next; } @@ -238,7 +243,7 @@ void wxClassInfo::CleanUpClasses() wxClassInfo::sm_classTable = NULL; } -wxObject *wxCreateDynamicObject(const char *name) +wxObject *wxCreateDynamicObject(const wxChar *name) { if (wxClassInfo::sm_classTable) { @@ -253,7 +258,7 @@ wxObject *wxCreateDynamicObject(const char *name) wxClassInfo *info = wxClassInfo::sm_first; while (info) { - if (info->m_className && strcmp(info->m_className, name) == 0) + if (info->m_className && wxStrcmp(info->m_className, name) == 0) return info->CreateObject(); info = info->m_next; }