git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@24202
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
- bug in wxRect ctor from two [out of order] wxPoints fixed (Steve Cornett)
- status text is now restored after wxMenu help is shown in it
- bug in wxWindow::RemoveEventHandler() fixed (Yingjun Zhang)
- bug in wxRect ctor from two [out of order] wxPoints fixed (Steve Cornett)
- status text is now restored after wxMenu help is shown in it
- bug in wxWindow::RemoveEventHandler() fixed (Yingjun Zhang)
+- make it possible to use wxRTTI macros with namespaces (Benjamin I. Williams)
#define DECLARE_DYNAMIC_CLASS(name) \
public: \
#define DECLARE_DYNAMIC_CLASS(name) \
public: \
- static wxClassInfo sm_class##name; \
+ static wxClassInfo ms_classInfo; \
+ static wxObject* wxCreateObject(); \
virtual wxClassInfo *GetClassInfo() const \
virtual wxClassInfo *GetClassInfo() const \
- { return &name::sm_class##name; }
+ { return &name::ms_classInfo; }
#define DECLARE_DYNAMIC_CLASS_NO_ASSIGN(name) \
DECLARE_NO_ASSIGN_CLASS(name) \
#define DECLARE_DYNAMIC_CLASS_NO_ASSIGN(name) \
DECLARE_NO_ASSIGN_CLASS(name) \
// Single inheritance with one base class
#define IMPLEMENT_DYNAMIC_CLASS(name, basename) \
// Single inheritance with one base class
#define IMPLEMENT_DYNAMIC_CLASS(name, basename) \
- wxObject* wxConstructorFor##name() \
+ wxObject* name::wxCreateObject() \
- wxClassInfo name::sm_class##name(wxT(#name), \
- &basename::sm_class##basename, NULL, \
+ wxClassInfo name::ms_classInfo(wxT(#name), \
+ &basename::ms_classInfo, NULL, \
- (wxObjectConstructorFn) wxConstructorFor##name);
+ (wxObjectConstructorFn) name::wxCreateObject);
// Multiple inheritance with two base classes
#define IMPLEMENT_DYNAMIC_CLASS2(name, basename1, basename2) \
// Multiple inheritance with two base classes
#define IMPLEMENT_DYNAMIC_CLASS2(name, basename1, basename2) \
- wxObject* wxConstructorFor##name() \
+ wxObject* name::wxCreateObject() \
- wxClassInfo name::sm_class##name(wxT(#name), \
- &basename1::sm_class##basename1, \
- &basename2::sm_class##basename2, \
+ wxClassInfo name::ms_classInfo(wxT(#name), \
+ &basename1::ms_classInfo, \
+ &basename2::ms_classInfo, \
wxT(#basename2), (int) sizeof(name), \
wxT(#basename2), (int) sizeof(name), \
- (wxObjectConstructorFn) wxConstructorFor##name);
+ (wxObjectConstructorFn) name::wxCreateObject);
// -----------------------------------
// for abstract classes
// -----------------------------------
// for abstract classes
// Single inheritance with one base class
#define IMPLEMENT_ABSTRACT_CLASS(name, basename) \
// Single inheritance with one base class
#define IMPLEMENT_ABSTRACT_CLASS(name, basename) \
- wxClassInfo name::sm_class##name(wxT(#name), \
- &basename::sm_class##basename, NULL, \
+ wxClassInfo name::ms_classInfo(wxT(#name), \
+ &basename::ms_classInfo, NULL, \
(int) sizeof(name), (wxObjectConstructorFn) 0);
// Multiple inheritance with two base classes
#define IMPLEMENT_ABSTRACT_CLASS2(name, basename1, basename2) \
(int) sizeof(name), (wxObjectConstructorFn) 0);
// Multiple inheritance with two base classes
#define IMPLEMENT_ABSTRACT_CLASS2(name, basename1, basename2) \
- wxClassInfo name::sm_class##name(wxT(#name), \
- &basename1::sm_class##basename1, \
- &basename2::sm_class##basename2, \
+ wxClassInfo name::ms_classInfo(wxT(#name), \
+ &basename1::ms_classInfo, \
+ &basename2::ms_classInfo, \
(int) sizeof(name), \
(wxObjectConstructorFn) 0);
(int) sizeof(name), \
(wxObjectConstructorFn) 0);
#define IMPLEMENT_USER_EXPORTED_ABSTRACT_PLUGGABLE_CLASS2(name, basename1, basename2) \
IMPLEMENT_ABSTRACT_PLUGGABLE_CLASS2(name, basename1, basename2)
#define IMPLEMENT_USER_EXPORTED_ABSTRACT_PLUGGABLE_CLASS2(name, basename1, basename2) \
IMPLEMENT_ABSTRACT_PLUGGABLE_CLASS2(name, basename1, basename2)
-#define CLASSINFO(name) (&name::sm_class##name)
+#define CLASSINFO(name) (&name::ms_classInfo)
#else // !wxUSE_DYNAMIC_CLASSES
#else // !wxUSE_DYNAMIC_CLASSES
#endif // wxUSE_DYNAMIC_CLASSES
#endif // wxUSE_DYNAMIC_CLASSES
-#define wxIS_KIND_OF(obj, className) obj->IsKindOf(&className::sm_class##className)
+#define wxIS_KIND_OF(obj, className) obj->IsKindOf(&className::ms_classInfo)
// Just seems a bit nicer-looking (pretend it's not a macro)
// Just seems a bit nicer-looking (pretend it's not a macro)
-#define wxIsKindOf(obj, className) obj->IsKindOf(&className::sm_class##className)
+#define wxIsKindOf(obj, className) obj->IsKindOf(&className::ms_classInfo)
// to be replaced by dynamic_cast<> in the future
#define wxDynamicCast(obj, className) \
// to be replaced by dynamic_cast<> in the future
#define wxDynamicCast(obj, className) \
- ((className *) wxCheckDynamicCast((wxObject*)(obj), &className::sm_class##className))
+ ((className *) wxCheckDynamicCast((wxObject*)(obj), &className::ms_classInfo))
// The 'this' pointer is always true, so use this version
// to cast the this pointer and avoid compiler warnings.
#define wxDynamicCastThis(className) \
// The 'this' pointer is always true, so use this version
// to cast the this pointer and avoid compiler warnings.
#define wxDynamicCastThis(className) \
- (IsKindOf(&className::sm_class##className) ? (className *)(this) : (className *)0)
+ (IsKindOf(&className::ms_classInfo) ? (className *)(this) : (className *)0)
#ifdef HAVE_CONST_CAST
#define wxConstCast(obj, className) const_cast<className *>(obj)
#ifdef HAVE_CONST_CAST
#define wxConstCast(obj, className) const_cast<className *>(obj)
{
classInfo = (wxClassInfo *)node->GetData();
if ( classInfo->IsKindOf(CLASSINFO(wxModule)) &&
{
classInfo = (wxClassInfo *)node->GetData();
if ( classInfo->IsKindOf(CLASSINFO(wxModule)) &&
- (classInfo != (& (wxModule::sm_classwxModule))) )
+ (classInfo != (& (wxModule::ms_classInfo))) )
{
wxModule* module = (wxModule *)classInfo->CreateObject();
RegisterModule(module);
{
wxModule* module = (wxModule *)classInfo->CreateObject();
RegisterModule(module);
wxClassTypeInfo s_typeInfo(wxT_OBJECT_PTR , &wxObject::sm_classwxObject , NULL , NULL , typeid(wxObject*).name() ) ;
wxClassTypeInfo s_typeInfowxObject(wxT_OBJECT , &wxObject::sm_classwxObject , NULL , NULL , typeid(wxObject).name() ) ;
#else
wxClassTypeInfo s_typeInfo(wxT_OBJECT_PTR , &wxObject::sm_classwxObject , NULL , NULL , typeid(wxObject*).name() ) ;
wxClassTypeInfo s_typeInfowxObject(wxT_OBJECT , &wxObject::sm_classwxObject , NULL , NULL , typeid(wxObject).name() ) ;
#else
-wxClassInfo wxObject::sm_classwxObject( wxT("wxObject"), 0, 0,
+wxClassInfo wxObject::ms_classInfo( wxT("wxObject"), 0, 0,
(int) sizeof(wxObject),
(wxObjectConstructorFn) 0 );
#endif
(int) sizeof(wxObject),
(wxObjectConstructorFn) 0 );
#endif