X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/8887e2341acfbb4d2a5fc1cfd52c65406e6ba110..e32c4e60825e58a4f17872d6153c00352c8001d6:/src/common/msgout.cpp diff --git a/src/common/msgout.cpp b/src/common/msgout.cpp index e162226ed6..e6a079969e 100755 --- a/src/common/msgout.cpp +++ b/src/common/msgout.cpp @@ -32,12 +32,14 @@ #include "wx/string.h" #include "wx/ffile.h" #include "wx/app.h" + #include "wx/intl.h" #if wxUSE_GUI #include "wx/msgdlg.h" #endif // wxUSE_GUI #endif #include "wx/msgout.h" +#include "wx/log.h" #include #include @@ -50,16 +52,11 @@ wxMessageOutput* wxMessageOutput::ms_msgOut = 0; wxMessageOutput* wxMessageOutput::Get() { - // FIXME this is an hack - static bool inGet = FALSE; - - if(!ms_msgOut && wxTheApp && !inGet) + if ( !ms_msgOut && wxTheApp ) { - inGet = TRUE; - wxTheApp->DoInit(); + ms_msgOut = wxTheApp->CreateMessageOutput(); } - inGet = FALSE; return ms_msgOut; } @@ -101,10 +98,16 @@ void wxMessageOutputMessageBox::Printf(const wxChar* format, ...) out.PrintfV(format, args); va_end(args); + // the native MSW msg box understands the TABs, others don't #ifndef __WXMSW__ - out.Replace(wxT("\t"),wxT(" ")); + out.Replace(wxT("\t"), wxT(" ")); #endif - ::wxMessageBox(out); + + wxString title; + if ( wxTheApp ) + title.Printf(_("%s message"), wxTheApp->GetAppName().c_str()); + + ::wxMessageBox(out, title); } #endif // wxUSE_GUI @@ -115,15 +118,15 @@ void wxMessageOutputMessageBox::Printf(const wxChar* format, ...) void wxMessageOutputLog::Printf(const wxChar* format, ...) { + wxString out; + va_list args; va_start(args, format); - wxString out; out.PrintfV(format, args); va_end(args); - out.Replace(wxT("\t"),wxT(" ")); - // under Motif, wxMessageDialog needs a parent window, so we use - // wxLog, which is better than nothing + out.Replace(wxT("\t"), wxT(" ")); + ::wxLogMessage(wxT("%s"), out.c_str()); }