X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/530646ca27604e0c24a78d0eebd4cf7301b27bc5..e91e1e3d5cab263883c1cee1689c898b8f7c4ecd:/include/wx/meta/implicitconversion.h diff --git a/include/wx/meta/implicitconversion.h b/include/wx/meta/implicitconversion.h index 16ff312e4c..d596a6b248 100644 --- a/include/wx/meta/implicitconversion.h +++ b/include/wx/meta/implicitconversion.h @@ -3,7 +3,6 @@ // Purpose: Determine resulting type from implicit conversion // Author: Vaclav Slavik // Created: 2010-10-22 -// RCS-ID: $Id$ // Copyright: (c) 2010 Vaclav Slavik // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// @@ -30,18 +29,28 @@ namespace wxPrivate { +// Helper macro to define a constant inside a template class: it's needed +// because MSVC6 doesn't support initializing static integer members but the +// usual workaround of using enums instead doesn't work for Borland (at least +// in template classes). +#ifdef __VISUALC6__ + #define wxDEFINE_CLASS_INT_CONST(name, value) enum { name = value } +#else + #define wxDEFINE_CLASS_INT_CONST(name, value) static const int name = value +#endif + template struct TypeHierarchy { // consider unknown types (e.g. objects, pointers) to be of highest // level, always convert to them if they occur - enum { level = 9999 }; + wxDEFINE_CLASS_INT_CONST( level, 9999 ); }; #define WX_TYPE_HIERARCHY_LEVEL(level_num, type) \ template<> struct TypeHierarchy \ { \ - enum { level = level_num }; \ + wxDEFINE_CLASS_INT_CONST( level, level_num ); \ } WX_TYPE_HIERARCHY_LEVEL( 1, char); @@ -84,7 +93,7 @@ struct wxImplicitConversionType typedef typename wxIf < // if T2 is "higher" type, convert to it - (int)wxPrivate::TypeHierarchy::level < (int)wxPrivate::TypeHierarchy::level, + (int)(wxPrivate::TypeHierarchy::level) < (int)(wxPrivate::TypeHierarchy::level), T2, // otherwise use T1 T1