X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/340e97388e791961861ff752dd8d9559d861e825..c5ba48512424b7e543cadfccef304fe170bdf910:/include/wx/build.h diff --git a/include/wx/build.h b/include/wx/build.h index 60b8da0f4a..d3e60f1c3d 100644 --- a/include/wx/build.h +++ b/include/wx/build.h @@ -14,6 +14,19 @@ #include "wx/version.h" +// NB: This file contains macros for checking binary compatibility of libraries +// in multilib builds, plugins and user components. +// The WX_BUILD_OPTIONS_SIGNATURE macro expands into string that should +// uniquely identify binary compatible builds: i.e. if two builds of the +// library are binary compatible, their signature string should be the +// same; if two builds are binary incompatible, their signatures should +// be different. +// +// Therefore, wxUSE_XXX flags that affect binary compatibility (vtables, +// function signatures) should be accounted for here. So should compilers +// and compiler versions (but note that binary compatible compiler versions +// such as gcc-2.95.2 and gcc-2.95.3 should have same signature!). + // ---------------------------------------------------------------------------- // WX_BUILD_OPTIONS_SIGNATURE // ---------------------------------------------------------------------------- @@ -29,14 +42,10 @@ __WX_BO_STRINGIZE(x) "." __WX_BO_STRINGIZE(y) "." __WX_BO_STRINGIZE(z) #endif -#ifdef __WXDEBUG__ - #define __WX_BO_DEBUG "debug" -#else - #define __WX_BO_DEBUG "no debug" -#endif - -#if wxUSE_UNICODE - #define __WX_BO_UNICODE "Unicode" +#if wxUSE_UNICODE_UTF8 + #define __WX_BO_UNICODE "UTF-8" +#elif wxUSE_UNICODE_WCHAR + #define __WX_BO_UNICODE "wchar_t" #else #define __WX_BO_UNICODE "ANSI" #endif @@ -52,43 +61,11 @@ #define __WX_BO_COMPILER ",GCC " \ __WX_BO_STRINGIZE(__GNUC__) "." __WX_BO_STRINGIZE(__GNUC_MINOR__) #elif defined(__VISUALC__) - #define __WX_BO_COMPILER ",Visual C++" + #define __WX_BO_COMPILER ",Visual C++ " __WX_BO_STRINGIZE(_MSC_VER) #elif defined(__BORLANDC__) - - #if __BORLANDC__ >= 0x600 /* BCCX */ - #define __WX_BO_COMPILER_VER " 6.0" - #elif __BORLANDC__ >= 0x570 /* Kylix */ - #define __WX_BO_COMPILER_VER " 5.7" - #elif __BORLANDC__ >= 0x560 /* BCB++ 6 */ - #define __WX_BO_COMPILER_VER " 5.6" - #elif __BORLANDC__ >= 0x550 /* BCB++ 5, free command line */ - #define __WX_BO_COMPILER_VER " 5.5" - #elif __BORLANDC__ >= 0x520 /* BCB++ 1-4 */ - #define __WX_BO_COMPILER_VER " 5.02" - #elif __BORLANDC__ >= 0x500 /* BC++ 5 */ - #define __WX_BO_COMPILER_VER " 5.0" - #elif __BORLANDC__ >= 0x452 /* BC++ 4 */ - #define __WX_BO_COMPILER_VER " 4.0" - #elif __BORLANDC__ >= 0x410 /* BC++ 3.1 */ - #define __WX_BO_COMPILER_VER " 3.1" - #elif __BORLANDC__ >= 0x400 /* BC++ 3.0 */ - #define __WX_BO_COMPILER_VER " 3.0" - #elif __BORLANDC__ >= 0x200 /* BC++ 2.0 */ - #define __WX_BO_COMPILER_VER " 2.0" - #else - #define __WX_BO_COMPILER_VER - #endif - - #define __WX_BO_COMPILER ",Borland C++" __WX_BO_COMPILER_VER - + #define __WX_BO_COMPILER ",Borland C++" #elif defined(__DIGITALMARS__) - - #if defined(__DMC_VERSION_STRING__) - #define __WX_BO_COMPILER "," __DMC_VERSION_STRING__ - #else - #define __WX_BO_COMPILER ",DigitalMars" - #endif - + #define __WX_BO_COMPILER ",DigitalMars" #elif defined(__WATCOMC__) #define __WX_BO_COMPILER ",Watcom C++" #else @@ -96,15 +73,15 @@ #endif // WXWIN_COMPATIBILITY macros affect presence of virtual functions -#if WXWIN_COMPATIBILITY_2_2 - #define __WX_BO_WXWIN_COMPAT_2_2 ",compatible with 2.2" +#if WXWIN_COMPATIBILITY_2_6 + #define __WX_BO_WXWIN_COMPAT_2_6 ",compatible with 2.6" #else - #define __WX_BO_WXWIN_COMPAT_2_2 + #define __WX_BO_WXWIN_COMPAT_2_6 #endif -#if WXWIN_COMPATIBILITY_2_4 - #define __WX_BO_WXWIN_COMPAT_2_4 ",compatible with 2.4" +#if WXWIN_COMPATIBILITY_2_8 + #define __WX_BO_WXWIN_COMPAT_2_8 ",compatible with 2.8" #else - #define __WX_BO_WXWIN_COMPAT_2_4 + #define __WX_BO_WXWIN_COMPAT_2_8 #endif // deriving wxWin containers from STL ones changes them completely: @@ -113,14 +90,14 @@ #else #define __WX_BO_STL ",wx containers" #endif - + // This macro is passed as argument to wxConsoleApp::CheckBuildOptions() #define WX_BUILD_OPTIONS_SIGNATURE \ __WX_BO_VERSION(wxMAJOR_VERSION, wxMINOR_VERSION, wxRELEASE_NUMBER) \ - " (" __WX_BO_DEBUG "," __WX_BO_UNICODE \ + " (" __WX_BO_UNICODE \ __WX_BO_COMPILER \ __WX_BO_STL \ - __WX_BO_WXWIN_COMPAT_2_2 __WX_BO_WXWIN_COMPAT_2_4 \ + __WX_BO_WXWIN_COMPAT_2_6 __WX_BO_WXWIN_COMPAT_2_8 \ ")" @@ -131,37 +108,14 @@ // Use this macro to check build options. Adding it to a file in DLL will // ensure that the DLL checks build options in same way IMPLEMENT_APP() does. #define WX_CHECK_BUILD_OPTIONS(libName) \ - static bool wxCheckBuildOptions() \ + static struct wxBuildOptionsChecker \ { \ - wxAppConsole::CheckBuildOptions(WX_BUILD_OPTIONS_SIGNATURE, \ - libName); \ - return true; \ - }; \ - static bool gs_buildOptionsCheck = wxCheckBuildOptions(); - - -#if WXWIN_COMPATIBILITY_2_4 - -// ---------------------------------------------------------------------------- -// wxBuildOptions -// ---------------------------------------------------------------------------- - -// NB: Don't use this class in new code, it relies on the ctor being always -// inlined. WX_BUILD_OPTIONS_SIGNATURE always works. -class wxBuildOptions -{ -public: - // the ctor must be inline to get the compilation settings of the code - // which included this header - wxBuildOptions() : m_signature(WX_BUILD_OPTIONS_SIGNATURE) {} - -private: - const char *m_signature; - - // actually only CheckBuildOptions() should be our friend but well... - friend class wxAppConsole; -}; + wxBuildOptionsChecker() \ + { \ + wxAppConsole::CheckBuildOptions(WX_BUILD_OPTIONS_SIGNATURE, \ + libName); \ + } \ + } gs_buildOptionsCheck; -#endif // WXWIN_COMPATIBILITY_2_4 #endif // _WX_BUILD_H_