2002-07-24 19:29:53 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/msgout.h
|
|
|
|
// Purpose: wxMessageOutput class. Shows a message to the user
|
|
|
|
// Author: Mattia Barbon
|
|
|
|
// Modified by:
|
|
|
|
// Created: 17.07.02
|
|
|
|
// RCS-ID: $Id$
|
2005-05-04 18:57:50 +00:00
|
|
|
// Copyright: (c) Mattia Barbon
|
2004-05-23 20:53:33 +00:00
|
|
|
// Licence: wxWindows licence
|
2002-07-24 19:29:53 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_MSGOUT_H_
|
|
|
|
#define _WX_MSGOUT_H_
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// headers
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#include "wx/defs.h"
|
2007-03-19 14:45:38 +00:00
|
|
|
#include "wx/chartype.h"
|
2007-03-17 10:26:10 +00:00
|
|
|
#include "wx/strvararg.h"
|
2002-07-24 19:29:53 +00:00
|
|
|
|
2002-08-30 00:39:33 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxMessageOutput is a class abstracting formatted output target, i.e.
|
|
|
|
// something you can printf() to
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2007-03-17 10:26:10 +00:00
|
|
|
// NB: VC6 has a bug that causes linker errors if you have template methods
|
|
|
|
// in a class using __declspec(dllimport). The solution is to split such
|
|
|
|
// class into two classes, one that contains the template methods and does
|
|
|
|
// *not* use WXDLLIMPEXP_BASE and another class that contains the rest
|
|
|
|
// (with DLL linkage).
|
|
|
|
class wxMessageOutputBase
|
2002-07-24 19:29:53 +00:00
|
|
|
{
|
|
|
|
public:
|
2007-03-17 10:26:10 +00:00
|
|
|
virtual ~wxMessageOutputBase() { }
|
2002-07-24 19:29:53 +00:00
|
|
|
|
|
|
|
// show a message to the user
|
2007-04-26 11:40:04 +00:00
|
|
|
// void Printf(const wxString& format, ...) = 0;
|
2007-05-04 10:41:08 +00:00
|
|
|
WX_DEFINE_VARARG_FUNC_VOID(Printf, 1, (const wxFormatString&),
|
2007-05-03 10:50:25 +00:00
|
|
|
DoPrintfWchar, DoPrintfUtf8)
|
2007-04-26 11:40:04 +00:00
|
|
|
#ifdef __WATCOMC__
|
|
|
|
// workaround for http://bugzilla.openwatcom.org/show_bug.cgi?id=351
|
2007-05-06 14:11:14 +00:00
|
|
|
WX_VARARG_WATCOM_WORKAROUND(void, Printf, 1, (const wxString&),
|
|
|
|
(wxFormatString(f1)));
|
|
|
|
WX_VARARG_WATCOM_WORKAROUND(void, Printf, 1, (const wxCStrData&),
|
|
|
|
(wxFormatString(f1)));
|
|
|
|
WX_VARARG_WATCOM_WORKAROUND(void, Printf, 1, (const char*),
|
|
|
|
(wxFormatString(f1)));
|
|
|
|
WX_VARARG_WATCOM_WORKAROUND(void, Printf, 1, (const wchar_t*),
|
|
|
|
(wxFormatString(f1)));
|
2007-04-26 11:40:04 +00:00
|
|
|
#endif
|
2007-03-17 10:26:10 +00:00
|
|
|
|
2009-03-22 17:17:01 +00:00
|
|
|
// 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;
|
|
|
|
|
2007-03-17 10:26:10 +00:00
|
|
|
protected:
|
2007-04-18 09:34:35 +00:00
|
|
|
// NB: this is pure virtual so that it can be implemented in dllexported
|
|
|
|
// wxMessagOutput class
|
2007-05-03 10:50:25 +00:00
|
|
|
#if !wxUSE_UTF8_LOCALE_ONLY
|
|
|
|
virtual void DoPrintfWchar(const wxChar *format, ...) = 0;
|
|
|
|
#endif
|
|
|
|
#if wxUSE_UNICODE_UTF8
|
|
|
|
virtual void DoPrintfUtf8(const char *format, ...) = 0;
|
|
|
|
#endif
|
2007-03-17 10:26:10 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#ifdef __VISUALC__
|
|
|
|
// "non dll-interface class 'wxStringPrintfMixin' used as base interface
|
|
|
|
// for dll-interface class 'wxString'" -- this is OK in our case
|
2009-06-12 03:37:47 +00:00
|
|
|
#pragma warning (push)
|
2007-03-17 10:26:10 +00:00
|
|
|
#pragma warning (disable:4275)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
class WXDLLIMPEXP_BASE wxMessageOutput : public wxMessageOutputBase
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual ~wxMessageOutput() { }
|
2002-08-30 00:39:33 +00:00
|
|
|
|
2005-06-06 23:34:24 +00:00
|
|
|
// gets the current wxMessageOutput object (may be NULL during
|
|
|
|
// initialization or shutdown)
|
2002-07-24 19:29:53 +00:00
|
|
|
static wxMessageOutput* Get();
|
2002-08-30 00:39:33 +00:00
|
|
|
|
2002-07-24 19:29:53 +00:00
|
|
|
// sets the global wxMessageOutput instance; returns the previous one
|
|
|
|
static wxMessageOutput* Set(wxMessageOutput* msgout);
|
2002-08-30 00:39:33 +00:00
|
|
|
|
2007-04-18 09:34:35 +00:00
|
|
|
protected:
|
2007-05-03 10:50:25 +00:00
|
|
|
#if !wxUSE_UTF8_LOCALE_ONLY
|
|
|
|
virtual void DoPrintfWchar(const wxChar *format, ...);
|
|
|
|
#endif
|
|
|
|
#if wxUSE_UNICODE_UTF8
|
|
|
|
virtual void DoPrintfUtf8(const char *format, ...);
|
|
|
|
#endif
|
2007-04-18 09:34:35 +00:00
|
|
|
|
2002-07-24 19:29:53 +00:00
|
|
|
private:
|
|
|
|
static wxMessageOutput* ms_msgOut;
|
|
|
|
};
|
|
|
|
|
2007-03-17 10:26:10 +00:00
|
|
|
#ifdef __VISUALC__
|
2009-06-12 03:37:47 +00:00
|
|
|
#pragma warning (pop)
|
2007-03-17 10:26:10 +00:00
|
|
|
#endif
|
|
|
|
|
2005-06-06 23:34:24 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
2009-07-18 23:22:51 +00:00
|
|
|
// implementation which sends output to stderr or specified file
|
2005-06-06 23:34:24 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2008-05-23 23:28:13 +00:00
|
|
|
class WXDLLIMPEXP_BASE wxMessageOutputStderr : public wxMessageOutput
|
2005-06-06 23:34:24 +00:00
|
|
|
{
|
|
|
|
public:
|
2009-07-18 23:22:51 +00:00
|
|
|
wxMessageOutputStderr(FILE *fp = stderr) : m_fp(fp) { }
|
2005-06-06 23:34:24 +00:00
|
|
|
|
2007-04-12 21:13:05 +00:00
|
|
|
virtual void Output(const wxString& str);
|
2008-05-23 23:28:13 +00:00
|
|
|
|
2009-03-22 17:17:01 +00:00
|
|
|
protected:
|
2008-05-23 23:28:13 +00:00
|
|
|
// 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);
|
2009-07-18 23:22:51 +00:00
|
|
|
|
|
|
|
FILE *m_fp;
|
2005-06-06 23:34:24 +00:00
|
|
|
};
|
|
|
|
|
2002-08-30 00:39:33 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
2008-05-23 23:28:13 +00:00
|
|
|
// 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.
|
2002-08-30 00:39:33 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2008-05-23 23:28:13 +00:00
|
|
|
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
|
2002-07-24 19:29:53 +00:00
|
|
|
{
|
|
|
|
public:
|
2008-05-23 23:28:13 +00:00
|
|
|
wxMessageOutputBest(wxMessageOutputFlags flags = wxMSGOUT_PREFER_STDERR)
|
|
|
|
: m_flags(flags) { }
|
2002-07-24 19:29:53 +00:00
|
|
|
|
2007-04-12 21:13:05 +00:00
|
|
|
virtual void Output(const wxString& str);
|
2008-05-23 23:28:13 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
wxMessageOutputFlags m_flags;
|
2002-07-24 19:29:53 +00:00
|
|
|
};
|
|
|
|
|
2002-08-30 00:39:33 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// implementation which shows output in a message box
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2007-07-11 00:02:51 +00:00
|
|
|
#if wxUSE_GUI && wxUSE_MSGDLG
|
2002-07-24 19:29:53 +00:00
|
|
|
|
2003-07-02 01:59:24 +00:00
|
|
|
class WXDLLIMPEXP_CORE wxMessageOutputMessageBox : public wxMessageOutput
|
2002-07-24 19:29:53 +00:00
|
|
|
{
|
|
|
|
public:
|
2002-08-30 00:39:33 +00:00
|
|
|
wxMessageOutputMessageBox() { }
|
2002-07-24 19:29:53 +00:00
|
|
|
|
2007-04-12 21:13:05 +00:00
|
|
|
virtual void Output(const wxString& str);
|
2002-07-24 19:29:53 +00:00
|
|
|
};
|
|
|
|
|
2007-07-11 00:02:51 +00:00
|
|
|
#endif // wxUSE_GUI && wxUSE_MSGDLG
|
2002-07-24 19:29:53 +00:00
|
|
|
|
2003-06-24 00:56:19 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// implementation using the native way of outputting debug messages
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2008-05-23 23:28:13 +00:00
|
|
|
class WXDLLIMPEXP_BASE wxMessageOutputDebug : public wxMessageOutputStderr
|
2003-06-24 00:56:19 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
wxMessageOutputDebug() { }
|
|
|
|
|
2007-04-12 21:13:05 +00:00
|
|
|
virtual void Output(const wxString& str);
|
2003-06-24 00:56:19 +00:00
|
|
|
};
|
|
|
|
|
2002-08-30 00:39:33 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// implementation using wxLog (mainly for backwards compatibility)
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2003-07-02 01:59:24 +00:00
|
|
|
class WXDLLIMPEXP_BASE wxMessageOutputLog : public wxMessageOutput
|
2002-07-24 19:29:53 +00:00
|
|
|
{
|
|
|
|
public:
|
2002-08-30 00:39:33 +00:00
|
|
|
wxMessageOutputLog() { }
|
2002-07-24 19:29:53 +00:00
|
|
|
|
2007-04-12 21:13:05 +00:00
|
|
|
virtual void Output(const wxString& str);
|
2002-07-24 19:29:53 +00:00
|
|
|
};
|
|
|
|
|
2008-05-23 23:28:13 +00:00
|
|
|
#endif // _WX_MSGOUT_H_
|