X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/dd435a79ed2c79e20621fbe6b1013a86a9e05fed..13de0c8c9b6b3d2e8ce5a21388f5f104b2f68338:/include/wx/app.h?ds=sidebyside diff --git a/include/wx/app.h b/include/wx/app.h index f172a41422..b2e7a337b9 100644 --- a/include/wx/app.h +++ b/include/wx/app.h @@ -117,6 +117,12 @@ public: virtual void OnFatalException() { } #if wxUSE_EXCEPTIONS + // function called if an uncaught exception is caught inside the main + // event loop: it may return true to continue running the event loop or + // false to stop it (in the latter case it may rethrow the exception as + // well) + virtual bool OnExceptionInMainLoop(); + // Called when an unhandled C++ exception occurs inside OnRun(): note that // the exception type is lost by now, so if you really want to handle the // exception you should override OnRun() and put a try/catch around @@ -621,20 +627,26 @@ public: // we need HINSTANCE declaration to define WinMain() #include "wx/msw/wrapwin.h" - #ifdef SW_SHOWNORMAL - #define wxSW_SHOWNORMAL SW_SHOWNORMAL + #ifndef SW_SHOWNORMAL + #define SW_SHOWNORMAL 1 + #endif + + // WinMain() is always ANSI, even in Unicode build, under normal Windows + // but is always Unicode under CE + #ifdef __WXWINCE__ + typedef wchar_t *wxCmdLineArgType; #else - #define wxSW_SHOWNORMAL 0 + typedef char *wxCmdLineArgType; #endif #define IMPLEMENT_WXWIN_MAIN \ extern int wxEntry(HINSTANCE hInstance, \ HINSTANCE hPrevInstance = NULL, \ - char *pCmdLine = NULL, \ - int nCmdShow = wxSW_SHOWNORMAL); \ + wxCmdLineArgType pCmdLine = NULL, \ + int nCmdShow = SW_SHOWNORMAL); \ extern "C" int WINAPI WinMain(HINSTANCE hInstance, \ HINSTANCE hPrevInstance, \ - char *lpCmdLine, \ + wxCmdLineArgType lpCmdLine, \ int nCmdShow) \ { \ return wxEntry(hInstance, hPrevInstance, lpCmdLine, nCmdShow); \