1 ///////////////////////////////////////////////////////////////////////////////
3 // Purpose: wxMessageOutput class. Shows a message to the user
4 // Author: Mattia Barbon
8 // Copyright: (c) Mattia Barbon
9 // Licence: wxWindows licence
10 ///////////////////////////////////////////////////////////////////////////////
15 // ----------------------------------------------------------------------------
17 // ----------------------------------------------------------------------------
20 #include "wx/chartype.h"
21 #include "wx/strvararg.h"
23 // ----------------------------------------------------------------------------
24 // wxMessageOutput is a class abstracting formatted output target, i.e.
25 // something you can printf() to
26 // ----------------------------------------------------------------------------
28 // NB: VC6 has a bug that causes linker errors if you have template methods
29 // in a class using __declspec(dllimport). The solution is to split such
30 // class into two classes, one that contains the template methods and does
31 // *not* use WXDLLIMPEXP_BASE and another class that contains the rest
32 // (with DLL linkage).
33 class wxMessageOutputBase
36 virtual ~wxMessageOutputBase() { }
38 // show a message to the user
39 // void Printf(const wxChar* format, ...) ATTRIBUTE_PRINTF_2 = 0;
40 WX_DEFINE_VARARG_FUNC_VOID(Printf
, DoPrintf
)
43 void DoPrintf(const wxChar
* format
, ...) ATTRIBUTE_PRINTF_2
;
44 virtual void Output(const wxString
& str
) = 0;
48 // "non dll-interface class 'wxStringPrintfMixin' used as base interface
49 // for dll-interface class 'wxString'" -- this is OK in our case
50 #pragma warning (disable:4275)
53 class WXDLLIMPEXP_BASE wxMessageOutput
: public wxMessageOutputBase
56 virtual ~wxMessageOutput() { }
58 // gets the current wxMessageOutput object (may be NULL during
59 // initialization or shutdown)
60 static wxMessageOutput
* Get();
62 // sets the global wxMessageOutput instance; returns the previous one
63 static wxMessageOutput
* Set(wxMessageOutput
* msgout
);
66 static wxMessageOutput
* ms_msgOut
;
70 #pragma warning (default:4275)
73 // ----------------------------------------------------------------------------
74 // implementation showing the message to the user in "best" possible way: uses
75 // native message box if available (currently only under Windows) and stderr
76 // otherwise; unlike wxMessageOutputMessageBox this class is always safe to use
77 // ----------------------------------------------------------------------------
79 class WXDLLIMPEXP_BASE wxMessageOutputBest
: public wxMessageOutput
82 wxMessageOutputBest() { }
85 virtual void Output(const wxString
& str
);
88 // ----------------------------------------------------------------------------
89 // implementation which sends output to stderr
90 // ----------------------------------------------------------------------------
92 class WXDLLIMPEXP_BASE wxMessageOutputStderr
: public wxMessageOutput
95 wxMessageOutputStderr() { }
98 virtual void Output(const wxString
& str
);
101 // ----------------------------------------------------------------------------
102 // implementation which shows output in a message box
103 // ----------------------------------------------------------------------------
107 class WXDLLIMPEXP_CORE wxMessageOutputMessageBox
: public wxMessageOutput
110 wxMessageOutputMessageBox() { }
113 virtual void Output(const wxString
& str
);
118 // ----------------------------------------------------------------------------
119 // implementation using the native way of outputting debug messages
120 // ----------------------------------------------------------------------------
122 class WXDLLIMPEXP_BASE wxMessageOutputDebug
: public wxMessageOutput
125 wxMessageOutputDebug() { }
128 virtual void Output(const wxString
& str
);
131 // ----------------------------------------------------------------------------
132 // implementation using wxLog (mainly for backwards compatibility)
133 // ----------------------------------------------------------------------------
135 class WXDLLIMPEXP_BASE wxMessageOutputLog
: public wxMessageOutput
138 wxMessageOutputLog() { }
141 virtual void Output(const wxString
& str
);