X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/ef357cdac22a9386c396b872e894d6818e05243a..1eb1eae717bea7942825313db9074529927db482:/src/common/msgout.cpp diff --git a/src/common/msgout.cpp b/src/common/msgout.cpp index 30e50e906b..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; } @@ -83,7 +80,7 @@ void wxMessageOutputStderr::Printf(const wxChar* format, ...) out.PrintfV(format, args); va_end(args); - fprintf(stderr, "%s", out.mb_str()); + fprintf(stderr, "%s", (const char*) out.mb_str()); } // ---------------------------------------------------------------------------- @@ -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("\t"," "); + 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("\t"," "); - // under Motif, wxMessageDialog needs a parent window, so we use - // wxLog, which is better than nothing - ::wxLogMessage("%s", out.c_str()); + out.Replace(wxT("\t"), wxT(" ")); + + ::wxLogMessage(wxT("%s"), out.c_str()); }