X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/2a7c760593b9774dc06e6824ad52058b770ba65a..b6a20a20d010d643e52914f51aa0700df0da925f:/include/wx/build.h diff --git a/include/wx/build.h b/include/wx/build.h index a9bf3923ab..60b8da0f4a 100644 --- a/include/wx/build.h +++ b/include/wx/build.h @@ -5,7 +5,7 @@ // Modified by: // Created: 07.05.02 // RCS-ID: $Id$ -// Copyright: (c) 2002 Vadim Zeitlin +// Copyright: (c) 2002 Vadim Zeitlin // Licence: wxWindows licence /////////////////////////////////////////////////////////////////////////////// @@ -18,7 +18,8 @@ // WX_BUILD_OPTIONS_SIGNATURE // ---------------------------------------------------------------------------- -#define __WX_BO_STRINGIZE(x) #x +#define __WX_BO_STRINGIZE(x) __WX_BO_STRINGIZE0(x) +#define __WX_BO_STRINGIZE0(x) #x #if (wxMINOR_VERSION % 2) == 0 #define __WX_BO_VERSION(x,y,z) \ @@ -39,13 +40,93 @@ #else #define __WX_BO_UNICODE "ANSI" #endif - + +// GCC and Intel C++ share same C++ ABI (and possibly others in the future), +// check if compiler versions are compatible: +#if defined(__GXX_ABI_VERSION) + #define __WX_BO_COMPILER \ + ",compiler with C++ ABI " __WX_BO_STRINGIZE(__GXX_ABI_VERSION) +#elif defined(__INTEL_COMPILER) + #define __WX_BO_COMPILER ",Intel C++" +#elif defined(__GNUG__) + #define __WX_BO_COMPILER ",GCC " \ + __WX_BO_STRINGIZE(__GNUC__) "." __WX_BO_STRINGIZE(__GNUC_MINOR__) +#elif defined(__VISUALC__) + #define __WX_BO_COMPILER ",Visual C++" +#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 + +#elif defined(__DIGITALMARS__) + + #if defined(__DMC_VERSION_STRING__) + #define __WX_BO_COMPILER "," __DMC_VERSION_STRING__ + #else + #define __WX_BO_COMPILER ",DigitalMars" + #endif + +#elif defined(__WATCOMC__) + #define __WX_BO_COMPILER ",Watcom C++" +#else + #define __WX_BO_COMPILER +#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" +#else + #define __WX_BO_WXWIN_COMPAT_2_2 +#endif +#if WXWIN_COMPATIBILITY_2_4 + #define __WX_BO_WXWIN_COMPAT_2_4 ",compatible with 2.4" +#else + #define __WX_BO_WXWIN_COMPAT_2_4 +#endif + +// deriving wxWin containers from STL ones changes them completely: +#if wxUSE_STL + #define __WX_BO_STL ",STL containers" +#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_DEBUG "," __WX_BO_UNICODE \ + __WX_BO_COMPILER \ + __WX_BO_STL \ + __WX_BO_WXWIN_COMPAT_2_2 __WX_BO_WXWIN_COMPAT_2_4 \ + ")" +// ---------------------------------------------------------------------------- +// WX_CHECK_BUILD_OPTIONS +// ---------------------------------------------------------------------------- // 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. @@ -58,4 +139,29 @@ }; \ 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; +}; + +#endif // WXWIN_COMPATIBILITY_2_4 + #endif // _WX_BUILD_H_