-extern bool WXDLLEXPORT
-wxEntryStart(HINSTANCE hInstance,
- HINSTANCE hPrevInstance = NULL,
- wxCmdLineArgType pCmdLine = NULL,
- int nCmdShow = SW_SHOWNORMAL);
-
-extern int WXDLLEXPORT
-wxEntry(HINSTANCE hInstance,
- HINSTANCE hPrevInstance = NULL,
- wxCmdLineArgType pCmdLine = NULL,
- int nCmdShow = SW_SHOWNORMAL);
+extern WXDLLIMPEXP_CORE bool
+ wxEntryStart(HINSTANCE hInstance,
+ HINSTANCE hPrevInstance = NULL,
+ wxCmdLineArgType pCmdLine = NULL,
+ int nCmdShow = SW_SHOWNORMAL);
+
+extern WXDLLIMPEXP_CORE int
+ wxEntry(HINSTANCE hInstance,
+ HINSTANCE hPrevInstance = NULL,
+ wxCmdLineArgType pCmdLine = NULL,
+ int nCmdShow = SW_SHOWNORMAL);
+
+#if defined(__BORLANDC__) && wxUSE_UNICODE
+ // Borland C++ has the following nonstandard behaviour: when the -WU
+ // command line flag is used, the linker expects to find wWinMain instead
+ // of WinMain. This flag causes the compiler to define _UNICODE and
+ // UNICODE symbols and there's no way to detect its use, so we have to
+ // define both WinMain and wWinMain so that IMPLEMENT_WXWIN_MAIN works
+ // for both code compiled with and without -WU.
+ // See http://sourceforge.net/tracker/?func=detail&atid=309863&aid=1935997&group_id=9863
+ // for more details.
+ #define IMPLEMENT_WXWIN_MAIN_BORLAND_NONSTANDARD \
+ extern "C" int WINAPI wWinMain(HINSTANCE hInstance, \
+ HINSTANCE hPrevInstance, \
+ wchar_t * WXUNUSED(lpCmdLine), \
+ int nCmdShow) \
+ { \
+ /* NB: wxEntry expects lpCmdLine argument to be char*, not */ \
+ /* wchar_t*, but fortunately it's not used anywhere */ \
+ /* and we can simply pass NULL in: */ \
+ return wxEntry(hInstance, hPrevInstance, NULL, nCmdShow); \
+ }
+#else
+ #define IMPLEMENT_WXWIN_MAIN_BORLAND_NONSTANDARD
+#endif // defined(__BORLANDC__) && wxUSE_UNICODE