X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e2478fde622a16d25c66690af353dfdc37e7b582..c6a6bbbf637a5a580b7ab182483d27522f5e3189:/src/common/msgout.cpp diff --git a/src/common/msgout.cpp b/src/common/msgout.cpp index 2baffdcf32..8fb5ed8066 100755 --- a/src/common/msgout.cpp +++ b/src/common/msgout.cpp @@ -1,11 +1,11 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: common/msgout.cpp +// Name: src/common/msgout.cpp // Purpose: wxMessageOutput implementation // Author: Mattia Barbon // Modified by: // Created: 17.07.02 // RCS-ID: $Id$ -// Copyright: (c) the wxWindows team +// Copyright: (c) the wxWidgets team // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// @@ -17,10 +17,6 @@ // headers // --------------------------------------------------------------------------- -#ifdef __GNUG__ - #pragma implementation "msgout.h" -#endif - // For compilers that support precompilation, includes "wx.h". #include "wx/wxprec.h" @@ -33,22 +29,29 @@ #include "wx/ffile.h" #include "wx/app.h" #include "wx/intl.h" + #include "wx/log.h" #if wxUSE_GUI #include "wx/msgdlg.h" #endif // wxUSE_GUI #endif #include "wx/msgout.h" -#include "wx/log.h" - +#include "wx/apptrait.h" #include #include +#if defined(__WINDOWS__) + #include "wx/msw/private.h" +#endif +#ifdef __WXMAC__ + #include "wx/mac/private.h" +#endif + // =========================================================================== // implementation // =========================================================================== -#ifdef __WXBASE__ +#if wxUSE_BASE // ---------------------------------------------------------------------------- // wxMessageOutput @@ -60,7 +63,7 @@ wxMessageOutput* wxMessageOutput::Get() { if ( !ms_msgOut && wxTheApp ) { - ms_msgOut = wxTheApp->CreateMessageOutput(); + ms_msgOut = wxTheApp->GetTraits()->CreateMessageOutput(); } return ms_msgOut; @@ -73,11 +76,51 @@ wxMessageOutput* wxMessageOutput::Set(wxMessageOutput* msgout) return old; } +// ---------------------------------------------------------------------------- +// wxMessageOutputBest +// ---------------------------------------------------------------------------- + +#ifdef __WINDOWS__ + +// check if we're running in a console under Windows +static inline bool IsInConsole() +{ +#ifdef __WXWINCE__ + return false; +#else // !__WXWINCE__ + HANDLE hStdErr = ::GetStdHandle(STD_ERROR_HANDLE); + return hStdErr && hStdErr != INVALID_HANDLE_VALUE; +#endif // __WXWINCE__/!__WXWINCE__ +} + +#endif // __WINDOWS__ + +void wxMessageOutputBest::DoPrintf(const wxChar* format, ...) +{ + va_list args; + va_start(args, format); + wxString out; + + out.PrintfV(format, args); + va_end(args); + +#ifdef __WINDOWS__ + if ( !IsInConsole() ) + { + ::MessageBox(NULL, out, _T("wxWidgets"), MB_ICONINFORMATION | MB_OK); + } + else +#endif // __WINDOWS__/!__WINDOWS__ + { + fprintf(stderr, "%s", (const char*) out.mb_str()); + } +} + // ---------------------------------------------------------------------------- // wxMessageOutputStderr // ---------------------------------------------------------------------------- -void wxMessageOutputStderr::Printf(const wxChar* format, ...) +void wxMessageOutputStderr::DoPrintf(const wxChar* format, ...) { va_list args; va_start(args, format); @@ -93,7 +136,7 @@ void wxMessageOutputStderr::Printf(const wxChar* format, ...) // wxMessageOutputDebug // ---------------------------------------------------------------------------- -void wxMessageOutputDebug::Printf(const wxChar* format, ...) +void wxMessageOutputDebug::DoPrintf(const wxChar* format, ...) { wxString out; @@ -105,13 +148,13 @@ void wxMessageOutputDebug::Printf(const wxChar* format, ...) #if defined(__WXMSW__) && !defined(__WXMICROWIN__) out.Replace(wxT("\t"), wxT(" ")); - out += _T("\r\n"); + out.Replace(wxT("\n"), wxT("\r\n")); ::OutputDebugString(out); #elif defined(__WXMAC__) && !defined(__DARWIN__) if ( wxIsDebuggerRunning() ) { Str255 pstr; - wxString output = str + wxT(";g") ; + wxString output = out + wxT(";g") ; wxMacStringToPascal(output.c_str(), pstr); #ifdef __powerc @@ -120,9 +163,11 @@ void wxMessageOutputDebug::Printf(const wxChar* format, ...) SysBreakStr(pstr); #endif } -#else // !MSW, !Mac - wxFputs(out, stderr); - fflush(stderr); +#else + wxFputs( out , stderr ) ; + if ( out.Right(1) != wxT("\n") ) + wxFputs( wxT("\n") , stderr ) ; + fflush( stderr ) ; #endif // platform } @@ -130,7 +175,7 @@ void wxMessageOutputDebug::Printf(const wxChar* format, ...) // wxMessageOutputLog // ---------------------------------------------------------------------------- -void wxMessageOutputLog::Printf(const wxChar* format, ...) +void wxMessageOutputLog::DoPrintf(const wxChar* format, ...) { wxString out; @@ -145,7 +190,7 @@ void wxMessageOutputLog::Printf(const wxChar* format, ...) ::wxLogMessage(wxT("%s"), out.c_str()); } -#endif // __WXBASE__ +#endif // wxUSE_BASE // ---------------------------------------------------------------------------- // wxMessageOutputMessageBox @@ -153,7 +198,7 @@ void wxMessageOutputLog::Printf(const wxChar* format, ...) #if wxUSE_GUI -void wxMessageOutputMessageBox::Printf(const wxChar* format, ...) +void wxMessageOutputMessageBox::DoPrintf(const wxChar* format, ...) { va_list args; va_start(args, format); @@ -175,4 +220,3 @@ void wxMessageOutputMessageBox::Printf(const wxChar* format, ...) } #endif // wxUSE_GUI -