put the write end of the pipe in non blocking mode to avoid deadlocks and return...
[wxWidgets.git] / src / common / msgout.cpp
CommitLineData
74698d3a
MB
1/////////////////////////////////////////////////////////////////////////////
2// Name: common/msgout.cpp
3// Purpose: wxMessageOutput implementation
4// Author: Mattia Barbon
5// Modified by:
6// Created: 17.07.02
7// RCS-ID: $Id$
77ffb593 8// Copyright: (c) the wxWidgets team
65571936 9// Licence: wxWindows licence
74698d3a
MB
10/////////////////////////////////////////////////////////////////////////////
11
12// ============================================================================
13// declarations
14// ============================================================================
15
16// ---------------------------------------------------------------------------
17// headers
18// ---------------------------------------------------------------------------
19
e4844687
SN
20#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) && !defined(__EMX__)
21// Some older compilers (such as EMX) cannot handle
22// #pragma interface/implementation correctly, iff
23// #pragma implementation is used in _two_ translation
24// units (as created by e.g. event.cpp compiled for
25// libwx_base and event.cpp compiled for libwx_gui_core).
26// So we must not use those pragmas for those compilers in
27// such files.
74698d3a
MB
28 #pragma implementation "msgout.h"
29#endif
30
31// For compilers that support precompilation, includes "wx.h".
32#include "wx/wxprec.h"
33
34#if defined(__BORLANDC__)
35 #pragma hdrstop
36#endif
37
38#ifndef WX_PRECOMP
39 #include "wx/string.h"
40 #include "wx/ffile.h"
41 #include "wx/app.h"
a90253f0 42 #include "wx/intl.h"
74698d3a
MB
43 #if wxUSE_GUI
44 #include "wx/msgdlg.h"
45 #endif // wxUSE_GUI
46#endif
47
48#include "wx/msgout.h"
7219fc4f 49#include "wx/apptrait.h"
1303a240 50#include "wx/log.h"
f7a75af1 51
74698d3a
MB
52#include <stdarg.h>
53#include <stdio.h>
54
e6b02f3f
VS
55#ifdef __WXMSW__
56 #include "wx/msw/private.h"
57#endif
0ff5799a
SC
58#ifdef __WXMAC__
59 #include "wx/mac/private.h"
60#endif
e6b02f3f 61
74698d3a
MB
62// ===========================================================================
63// implementation
64// ===========================================================================
65
ec67cff1 66#if wxUSE_BASE
e2478fde
VZ
67
68// ----------------------------------------------------------------------------
69// wxMessageOutput
70// ----------------------------------------------------------------------------
71
74698d3a
MB
72wxMessageOutput* wxMessageOutput::ms_msgOut = 0;
73
74wxMessageOutput* wxMessageOutput::Get()
75{
a69be60b 76 if ( !ms_msgOut && wxTheApp )
e02911a2 77 {
dc6d5e38 78 ms_msgOut = wxTheApp->GetTraits()->CreateMessageOutput();
e02911a2
MB
79 }
80
74698d3a
MB
81 return ms_msgOut;
82}
83
84wxMessageOutput* wxMessageOutput::Set(wxMessageOutput* msgout)
85{
86 wxMessageOutput* old = ms_msgOut;
87 ms_msgOut = msgout;
88 return old;
89}
90
91// ----------------------------------------------------------------------------
92// wxMessageOutputStderr
93// ----------------------------------------------------------------------------
94
95void wxMessageOutputStderr::Printf(const wxChar* format, ...)
96{
97 va_list args;
98 va_start(args, format);
99 wxString out;
100
101 out.PrintfV(format, args);
102 va_end(args);
103
401eb3de 104 fprintf(stderr, "%s", (const char*) out.mb_str());
74698d3a
MB
105}
106
107// ----------------------------------------------------------------------------
e2478fde 108// wxMessageOutputDebug
74698d3a
MB
109// ----------------------------------------------------------------------------
110
e2478fde 111void wxMessageOutputDebug::Printf(const wxChar* format, ...)
74698d3a 112{
e2478fde
VZ
113 wxString out;
114
74698d3a
MB
115 va_list args;
116 va_start(args, format);
74698d3a
MB
117
118 out.PrintfV(format, args);
119 va_end(args);
120
e2478fde 121#if defined(__WXMSW__) && !defined(__WXMICROWIN__)
311da78a 122 out.Replace(wxT("\t"), wxT(" "));
7e6f48d1 123 out.Replace(wxT("\n"), wxT("\r\n"));
e2478fde 124 ::OutputDebugString(out);
7873ca31
SC
125#elif defined(__WXMAC__)
126#if !defined(__DARWIN__)
e2478fde
VZ
127 if ( wxIsDebuggerRunning() )
128 {
129 Str255 pstr;
0ff5799a 130 wxString output = out + wxT(";g") ;
e2478fde
VZ
131 wxMacStringToPascal(output.c_str(), pstr);
132
133 #ifdef __powerc
134 DebugStr(pstr);
135 #else
136 SysBreakStr(pstr);
137 #endif
138 }
7873ca31
SC
139#else
140 wxFputs( out , stderr ) ;
141 if ( out.Right(1) != wxT("\n") )
142 wxFputs( wxT("\n") , stderr ) ;
143 fflush( stderr ) ;
144#endif
e2478fde 145#else // !MSW, !Mac
46446cc2
VZ
146 // FIXME: why is wxFputs() not defined under Linux?
147 fputs(out.mb_str(), stderr);
e2478fde
VZ
148 fflush(stderr);
149#endif // platform
74698d3a
MB
150}
151
74698d3a
MB
152// ----------------------------------------------------------------------------
153// wxMessageOutputLog
154// ----------------------------------------------------------------------------
155
74698d3a
MB
156void wxMessageOutputLog::Printf(const wxChar* format, ...)
157{
a69be60b
VZ
158 wxString out;
159
74698d3a
MB
160 va_list args;
161 va_start(args, format);
74698d3a
MB
162
163 out.PrintfV(format, args);
164 va_end(args);
165
311da78a 166 out.Replace(wxT("\t"), wxT(" "));
a69be60b 167
8887e234 168 ::wxLogMessage(wxT("%s"), out.c_str());
74698d3a 169}
e2478fde 170
ec67cff1 171#endif // wxUSE_BASE
e2478fde
VZ
172
173// ----------------------------------------------------------------------------
174// wxMessageOutputMessageBox
175// ----------------------------------------------------------------------------
176
177#if wxUSE_GUI
178
179void wxMessageOutputMessageBox::Printf(const wxChar* format, ...)
180{
181 va_list args;
182 va_start(args, format);
183 wxString out;
184
185 out.PrintfV(format, args);
186 va_end(args);
187
188 // the native MSW msg box understands the TABs, others don't
189#ifndef __WXMSW__
190 out.Replace(wxT("\t"), wxT(" "));
191#endif
192
193 wxString title;
194 if ( wxTheApp )
195 title.Printf(_("%s message"), wxTheApp->GetAppName().c_str());
196
197 ::wxMessageBox(out, title);
198}
199
200#endif // wxUSE_GUI
201