X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/634f6a1f0a5e863305bf1152e287fdf486433eee..2c18f21dc7d5aedd7100b02f7a721551b73c537b:/src/mgl/app.cpp diff --git a/src/mgl/app.cpp b/src/mgl/app.cpp index 164860cf2a..bcb909fcc8 100644 --- a/src/mgl/app.cpp +++ b/src/mgl/app.cpp @@ -27,6 +27,7 @@ #include "wx/dialog.h" #include "wx/log.h" #include "wx/intl.h" + #include "wx/resource.h" #endif #include "wx/app.h" @@ -36,12 +37,6 @@ #include "wx/univ/colschem.h" #include "wx/mgl/private.h" -#define MGL_DEBUG - -#if defined(MGL_DEBUG) && !defined(__WXDEBUG__) -#undef MGL_DEBUG -#endif - //----------------------------------------------------------------------------- // Global data //----------------------------------------------------------------------------- @@ -165,16 +160,16 @@ static bool wxCreateMGL_WM(const wxDisplayModeInfo& displayMode) refresh = wxSystemOptions::GetOptionInt(wxT("mgl.screen-refresh")); #endif - mode = MGL_findMode(displayMode.GetScreenSize().x, - displayMode.GetScreenSize().y, + mode = MGL_findMode(displayMode.GetWidth(), + displayMode.GetHeight(), displayMode.GetDepth()); if ( mode == -1 ) { - wxLogWarning(_("Mode %ix%i-%i not available, falling back to default mode."), - displayMode.GetScreenSize().x, - displayMode.GetScreenSize().y, + wxLogError(_("Mode %ix%i-%i not available."), + displayMode.GetWidth(), + displayMode.GetHeight(), displayMode.GetDepth()); - mode = 0; // always available + return FALSE; } g_displayDC = new MGLDisplayDC(mode, 1, refresh); if ( !g_displayDC->isValid() ) @@ -187,7 +182,7 @@ static bool wxCreateMGL_WM(const wxDisplayModeInfo& displayMode) g_winMng = MGL_wmCreate(g_displayDC->getDC()); if (!g_winMng) return FALSE; - + return TRUE; } @@ -218,7 +213,6 @@ END_EVENT_TABLE() wxApp::wxApp() : m_mainLoop(NULL) { - m_displayMode = wxDisplayModeInfo(wxSize(640, 480), 16); } wxApp::~wxApp() @@ -234,33 +228,35 @@ bool wxApp::SetDisplayMode(const wxDisplayModeInfo& mode) if ( g_displayDC != NULL ) { // FIXME_MGL -- we currently don't allow to switch video mode - // at runtime. This can hopefully be changed... + // more than once. This can hopefully be changed... wxFAIL_MSG(wxT("Can't change display mode after intialization!")); return FALSE; } + + if ( !wxCreateMGL_WM(mode) ) + return FALSE; + gs_rootWindow = new wxRootWindow; + m_displayMode = mode; + return TRUE; } bool wxApp::OnInitGui() { - if ( !wxCreateMGL_WM(m_displayMode) ) - return FALSE; - - // This has to be done *after* wxCreateMGL_WM() because it initializes - // wxUniv's themes if ( !wxAppBase::OnInitGui() ) return FALSE; - - // ...and this has to be done after wxUniv themes were initialized - gs_rootWindow = new wxRootWindow; -#ifdef MGL_DEBUG - // That damn MGL redirects stdin and stdout to physical console - FILE *file = fopen("stderr", "wt"); - wxLog::SetActiveTarget(new wxLogStderr(file)); +#ifdef __WXDEBUG__ + // MGL redirects stdout and stderr to physical console, so lets redirect + // it to file. Do it only when WXDEBUG environment variable is set + if ( wxGetEnv(wxT("WXDEBUG"), NULL) ) + freopen("output.err", "wt", stderr); #endif + wxLog *oldLog = wxLog::SetActiveTarget(new wxLogGui); + if ( oldLog ) delete oldLog; + return TRUE; } @@ -290,6 +286,11 @@ void wxApp::OnIdle(wxIdleEvent &event) // 'Garbage' collection of windows deleted with Close(). DeletePendingObjects(); +#if wxUSE_LOG + // flush the logged messages if any + wxLog::FlushActive(); +#endif // wxUSE_LOG + // Send OnIdle events to all windows if ( SendIdleEvents() ) event.RequestMore(TRUE); @@ -434,14 +435,7 @@ wxIcon wxApp::GetStdIcon(int which) const void wxApp::CleanUp() { - delete gs_rootWindow; - #if wxUSE_LOG - // flush the logged messages if any - wxLog *log = wxLog::GetActiveTarget(); - if (log != NULL && log->HasPendingMessages()) - log->Flush(); - // continuing to use user defined log target is unsafe from now on because // some resources may be already unavailable, so replace it by something // more safe @@ -450,6 +444,8 @@ void wxApp::CleanUp() delete oldlog; #endif // wxUSE_LOG + delete gs_rootWindow; + wxModule::CleanUpModules(); #if wxUSE_WX_RESOURCES @@ -613,6 +609,12 @@ int wxEntry(int argc, char *argv[]) } } +#if wxUSE_LOG + // flush the logged messages if any + wxLog *log = wxLog::GetActiveTarget(); + if (log != NULL && log->HasPendingMessages()) + log->Flush(); +#endif // wxUSE_LOG retValue = wxTheApp->OnExit(); } }