X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/74698d3a22d5e611bbcd731a3ade616c66cfaca6..22bfe96ca6b7248ab8161ec97963bca8e3be963e:/include/wx/msgout.h diff --git a/include/wx/msgout.h b/include/wx/msgout.h index 2576f19446..cab47aa087 100755 --- a/include/wx/msgout.h +++ b/include/wx/msgout.h @@ -16,63 +16,94 @@ // headers // ---------------------------------------------------------------------------- -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) && !defined(__EMX__) +// Some older compilers (such as EMX) cannot handle +// #pragma interface/implementation correctly, iff +// #pragma implementation is used in _two_ translation +// units (as created by e.g. event.cpp compiled for +// libwx_base and event.cpp compiled for libwx_gui_core). +// So we must not use those pragmas for those compilers in +// such files. #pragma interface "msgout.h" #endif #include "wx/defs.h" #include "wx/wxchar.h" -class WXDLLEXPORT wxMessageOutput +// ---------------------------------------------------------------------------- +// wxMessageOutput is a class abstracting formatted output target, i.e. +// something you can printf() to +// ---------------------------------------------------------------------------- + +class WXDLLIMPEXP_BASE wxMessageOutput { public: - virtual ~wxMessageOutput() {}; + virtual ~wxMessageOutput() { } // show a message to the user virtual void Printf(const wxChar* format, ...) ATTRIBUTE_PRINTF_2 = 0; + // gets the current wxMessageOutput object static wxMessageOutput* Get(); + // sets the global wxMessageOutput instance; returns the previous one static wxMessageOutput* Set(wxMessageOutput* msgout); + private: static wxMessageOutput* ms_msgOut; }; -// sends output to stderr -class WXDLLEXPORT wxMessageOutputStderr : public wxMessageOutput +// ---------------------------------------------------------------------------- +// implementation which sends output to stderr +// ---------------------------------------------------------------------------- + +class WXDLLIMPEXP_BASE wxMessageOutputStderr : public wxMessageOutput { public: - wxMessageOutputStderr() {}; + wxMessageOutputStderr() { } virtual void Printf(const wxChar* format, ...) ATTRIBUTE_PRINTF_2; }; +// ---------------------------------------------------------------------------- +// implementation which shows output in a message box +// ---------------------------------------------------------------------------- + #if wxUSE_GUI -// shows output in a message box -class WXDLLEXPORT wxMessageOutputMessageBox : public wxMessageOutput +class WXDLLIMPEXP_CORE wxMessageOutputMessageBox : public wxMessageOutput { public: - wxMessageOutputMessageBox() {}; + wxMessageOutputMessageBox() { } virtual void Printf(const wxChar* format, ...) ATTRIBUTE_PRINTF_2; }; -#ifdef __WXMOTIF__ +#endif // wxUSE_GUI + +// ---------------------------------------------------------------------------- +// implementation using the native way of outputting debug messages +// ---------------------------------------------------------------------------- -// use wxLog; this is only required for wxMotif, so we put this code -// inside wxUSE_GUI; it will work even without GUI -class WXDLLEXPORT wxMessageOutputLog : public wxMessageOutput +class WXDLLIMPEXP_BASE wxMessageOutputDebug : public wxMessageOutput { public: - wxMessageOutputLog() {}; + wxMessageOutputDebug() { } virtual void Printf(const wxChar* format, ...) ATTRIBUTE_PRINTF_2; }; -#endif // __WXMOTIF__ +// ---------------------------------------------------------------------------- +// implementation using wxLog (mainly for backwards compatibility) +// ---------------------------------------------------------------------------- + +class WXDLLIMPEXP_BASE wxMessageOutputLog : public wxMessageOutput +{ +public: + wxMessageOutputLog() { } -#endif // wxUSE_GUI + virtual void Printf(const wxChar* format, ...) ATTRIBUTE_PRINTF_2; +}; #endif // _WX_MSGOUT_H_