a7dddd9f3b
Add wxMessageOutputWithConv mix-in class to avoid duplicating the same code in wxLogStream and wxMessageOutputStderr. Also derive wxLogStderr from wxMessageOutputStderr to reuse its code without having to create a temporary object of this type (which will be more expensive now that doing it involves creating a heap-allocated conversion object copy).
172 lines
5.4 KiB
C++
172 lines
5.4 KiB
C++
///////////////////////////////////////////////////////////////////////////////
|
|
// Name: wx/msgout.h
|
|
// Purpose: wxMessageOutput class. Shows a message to the user
|
|
// Author: Mattia Barbon
|
|
// Modified by:
|
|
// Created: 17.07.02
|
|
// Copyright: (c) Mattia Barbon
|
|
// Licence: wxWindows licence
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
#ifndef _WX_MSGOUT_H_
|
|
#define _WX_MSGOUT_H_
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// headers
|
|
// ----------------------------------------------------------------------------
|
|
|
|
#include "wx/defs.h"
|
|
#include "wx/chartype.h"
|
|
#include "wx/strvararg.h"
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// wxMessageOutput is a class abstracting formatted output target, i.e.
|
|
// something you can printf() to
|
|
// ----------------------------------------------------------------------------
|
|
|
|
class WXDLLIMPEXP_BASE wxMessageOutput
|
|
{
|
|
public:
|
|
virtual ~wxMessageOutput() { }
|
|
|
|
// gets the current wxMessageOutput object (may be NULL during
|
|
// initialization or shutdown)
|
|
static wxMessageOutput* Get();
|
|
|
|
// sets the global wxMessageOutput instance; returns the previous one
|
|
static wxMessageOutput* Set(wxMessageOutput* msgout);
|
|
|
|
// show a message to the user
|
|
// void Printf(const wxString& format, ...) = 0;
|
|
WX_DEFINE_VARARG_FUNC_VOID(Printf, 1, (const wxFormatString&),
|
|
DoPrintfWchar, DoPrintfUtf8)
|
|
|
|
// called by DoPrintf() to output formatted string but can also be called
|
|
// directly if no formatting is needed
|
|
virtual void Output(const wxString& str) = 0;
|
|
|
|
protected:
|
|
#if !wxUSE_UTF8_LOCALE_ONLY
|
|
void DoPrintfWchar(const wxChar *format, ...);
|
|
#endif
|
|
#if wxUSE_UNICODE_UTF8
|
|
void DoPrintfUtf8(const char *format, ...);
|
|
#endif
|
|
|
|
private:
|
|
static wxMessageOutput* ms_msgOut;
|
|
};
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// helper mix-in for output targets that can use difference encodings
|
|
// ----------------------------------------------------------------------------
|
|
|
|
class WXDLLIMPEXP_BASE wxMessageOutputWithConv
|
|
{
|
|
protected:
|
|
explicit wxMessageOutputWithConv(const wxMBConv& conv)
|
|
: m_conv(conv.Clone())
|
|
{
|
|
}
|
|
|
|
~wxMessageOutputWithConv()
|
|
{
|
|
delete m_conv;
|
|
}
|
|
|
|
// return the string with "\n" appended if it doesn't already terminate
|
|
// with it (in which case it's returned unchanged)
|
|
wxString AppendLineFeedIfNeeded(const wxString& str);
|
|
|
|
// Prepare the given string for output by appending a new line to it, if
|
|
// necessary, and converting it to a narrow string using our conversion
|
|
// object.
|
|
wxCharBuffer PrepareForOutput(const wxString& str);
|
|
|
|
const wxMBConv* const m_conv;
|
|
};
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// implementation which sends output to stderr or specified file
|
|
// ----------------------------------------------------------------------------
|
|
|
|
class WXDLLIMPEXP_BASE wxMessageOutputStderr : public wxMessageOutput,
|
|
protected wxMessageOutputWithConv
|
|
{
|
|
public:
|
|
wxMessageOutputStderr(FILE *fp = stderr,
|
|
const wxMBConv &conv = wxConvWhateverWorks);
|
|
|
|
virtual void Output(const wxString& str) wxOVERRIDE;
|
|
|
|
protected:
|
|
FILE *m_fp;
|
|
|
|
wxDECLARE_NO_COPY_CLASS(wxMessageOutputStderr);
|
|
};
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// implementation showing the message to the user in "best" possible way:
|
|
// uses stderr or message box if available according to the flag given to ctor.
|
|
// ----------------------------------------------------------------------------
|
|
|
|
enum wxMessageOutputFlags
|
|
{
|
|
wxMSGOUT_PREFER_STDERR = 0, // use stderr if available (this is the default)
|
|
wxMSGOUT_PREFER_MSGBOX = 1 // always use message box if available
|
|
};
|
|
|
|
class WXDLLIMPEXP_BASE wxMessageOutputBest : public wxMessageOutputStderr
|
|
{
|
|
public:
|
|
wxMessageOutputBest(wxMessageOutputFlags flags = wxMSGOUT_PREFER_STDERR)
|
|
: m_flags(flags) { }
|
|
|
|
virtual void Output(const wxString& str) wxOVERRIDE;
|
|
|
|
private:
|
|
wxMessageOutputFlags m_flags;
|
|
};
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// implementation which shows output in a message box
|
|
// ----------------------------------------------------------------------------
|
|
|
|
#if wxUSE_GUI && wxUSE_MSGDLG
|
|
|
|
class WXDLLIMPEXP_CORE wxMessageOutputMessageBox : public wxMessageOutput
|
|
{
|
|
public:
|
|
wxMessageOutputMessageBox() { }
|
|
|
|
virtual void Output(const wxString& str) wxOVERRIDE;
|
|
};
|
|
|
|
#endif // wxUSE_GUI && wxUSE_MSGDLG
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// implementation using the native way of outputting debug messages
|
|
// ----------------------------------------------------------------------------
|
|
|
|
class WXDLLIMPEXP_BASE wxMessageOutputDebug : public wxMessageOutputStderr
|
|
{
|
|
public:
|
|
wxMessageOutputDebug() { }
|
|
|
|
virtual void Output(const wxString& str) wxOVERRIDE;
|
|
};
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// implementation using wxLog (mainly for backwards compatibility)
|
|
// ----------------------------------------------------------------------------
|
|
|
|
class WXDLLIMPEXP_BASE wxMessageOutputLog : public wxMessageOutput
|
|
{
|
|
public:
|
|
wxMessageOutputLog() { }
|
|
|
|
virtual void Output(const wxString& str) wxOVERRIDE;
|
|
};
|
|
|
|
#endif // _WX_MSGOUT_H_
|