X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/66dfed9b9d00326e79bdd314442288ba30be7cca..53f6aab75294c585e53e02b618a09dcb1dd97fb8:/src/common/appcmn.cpp diff --git a/src/common/appcmn.cpp b/src/common/appcmn.cpp index 608a40ea4e..c3461c2934 100644 --- a/src/common/appcmn.cpp +++ b/src/common/appcmn.cpp @@ -49,6 +49,10 @@ #include "wx/msw/private.h" // includes windows.h for MessageBox() #endif +#if defined(__WXMAC__) + #include "wx/mac/private.h" // includes mac headers +#endif + // =========================================================================== // implementation // =========================================================================== @@ -72,6 +76,11 @@ wxAppBase::wxAppBase() #endif // wxUSE_GUI } +wxAppBase::~wxAppBase() +{ + // this destructor is required for Darwin +} + #if wxUSE_GUI bool wxAppBase::OnInitGui() { @@ -166,7 +175,7 @@ bool wxAppBase::OnInit() OnInitCmdLine(parser); bool cont; - switch ( parser.Parse() ) + switch ( parser.Parse(FALSE /* don't show usage */) ) { case -1: cont = OnCmdLineHelp(parser); @@ -192,6 +201,7 @@ bool wxAppBase::OnInit() #define OPTION_VERBOSE _T("verbose") #define OPTION_THEME _T("theme") +#define OPTION_MODE _T("mode") void wxAppBase::OnInitCmdLine(wxCmdLineParser& parser) { @@ -226,6 +236,19 @@ void wxAppBase::OnInitCmdLine(wxCmdLineParser& parser) }, #endif // __WXUNIVERSAL__ +#if defined(__WXMGL__) + // VS: this is not specific to wxMGL, all fullscreen (framebuffer) ports + // should provide this option. That's why it is in common/appcmn.cpp + // and not mgl/app.cpp + { + wxCMD_LINE_OPTION, + _T(""), + OPTION_MODE, + gettext_noop("specify display mode to use (e.g. 640x480-16)"), + wxCMD_LINE_VAL_STRING + }, +#endif // __WXMGL__ + // terminator { wxCMD_LINE_NONE } }; @@ -258,6 +281,23 @@ bool wxAppBase::OnCmdLineParsed(wxCmdLineParser& parser) } #endif // __WXUNIVERSAL__ +#if defined(__WXMGL__) + wxString modeDesc; + if ( parser.Found(OPTION_MODE, &modeDesc) ) + { + unsigned w, h, bpp; + if ( wxSscanf(modeDesc.c_str(), _T("%ux%u-%u"), &w, &h, &bpp) != 3 ) + { + wxLogError(_("Invalid display mode specification '%s'."), modeDesc.c_str()); + + return FALSE; + } + + if ( !SetDisplayMode(wxDisplayModeInfo(w, h, bpp)) ) + return FALSE; + } +#endif // __WXMGL__ + return TRUE; } @@ -294,7 +334,7 @@ void wxTrap() { #if defined(__WXMSW__) && !defined(__WXMICROWIN__) DebugBreak(); -#elif defined(__WXMAC__) +#elif defined(__WXMAC__) && !defined(__DARWIN__) #if __powerc Debugger(); #else @@ -313,19 +353,6 @@ void ShowAssertDialog(const wxChar *szFile, int nLine, const wxChar *szMsg) { // this variable can be set to true to suppress "assert failure" messages static bool s_bNoAsserts = FALSE; - static bool s_bInAssert = FALSE; // FIXME MT-unsafe - - if ( s_bInAssert ) - { - // He-e-e-e-elp!! we're trapped in endless loop - wxTrap(); - - s_bInAssert = FALSE; - - return; - } - - s_bInAssert = TRUE; wxChar szBuf[4096]; @@ -396,13 +423,26 @@ void ShowAssertDialog(const wxChar *szFile, int nLine, const wxChar *szMsg) wxTrap(); #endif // GUI/!GUI } - - s_bInAssert = FALSE; } // this function is called when an assert fails void wxOnAssert(const wxChar *szFile, int nLine, const wxChar *szMsg) { + // FIXME MT-unsafe + static bool s_bInAssert = FALSE; + + if ( s_bInAssert ) + { + // He-e-e-e-elp!! we're trapped in endless loop + wxTrap(); + + s_bInAssert = FALSE; + + return; + } + + s_bInAssert = TRUE; + if ( !wxTheApp ) { // by default, show the assert dialog box - we can't customize this @@ -414,6 +454,8 @@ void wxOnAssert(const wxChar *szFile, int nLine, const wxChar *szMsg) // let the app process it as it wants wxTheApp->OnAssert(szFile, nLine, szMsg); } + + s_bInAssert = FALSE; } void wxAppBase::OnAssert(const wxChar *file, int line, const wxChar *msg)