1 /////////////////////////////////////////////////////////////////////////////
2 // Name: wx/generic/logg.h
3 // Purpose: Assorted wxLogXXX functions, and wxLog (sink for logs)
4 // Author: Vadim Zeitlin
8 // Copyright: (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
17 class WXDLLIMPEXP_FWD_CORE wxTextCtrl
;
18 class WXDLLIMPEXP_FWD_CORE wxLogFrame
;
19 class WXDLLIMPEXP_FWD_CORE wxWindow
;
21 // ----------------------------------------------------------------------------
22 // the following log targets are only compiled in if the we're compiling the
23 // GUI part (andnot just the base one) of the library, they're implemented in
24 // src/generic/logg.cpp *and not src/common/log.cpp unlike all the rest)
25 // ----------------------------------------------------------------------------
29 // log everything to a text window (GUI only of course)
30 class WXDLLIMPEXP_CORE wxLogTextCtrl
: public wxLog
33 wxLogTextCtrl(wxTextCtrl
*pTextCtrl
);
36 // implement sink function
37 virtual void DoLogText(const wxString
& msg
);
41 wxTextCtrl
*m_pTextCtrl
;
43 wxDECLARE_NO_COPY_CLASS(wxLogTextCtrl
);
46 #endif // wxUSE_TEXTCTRL
48 // ----------------------------------------------------------------------------
49 // GUI log target, the default one for wxWidgets programs
50 // ----------------------------------------------------------------------------
54 class WXDLLIMPEXP_CORE wxLogGui
: public wxLog
60 // show all messages that were logged since the last Flush()
64 virtual void DoLogRecord(wxLogLevel level
,
66 const wxLogRecordInfo
& info
);
68 // return the title to be used for the log dialog, depending on m_bErrors
69 // and m_bWarnings values
70 wxString
GetTitle() const;
72 // return the icon (one of wxICON_XXX constants) to be used for the dialog
73 // depending on m_bErrors/m_bWarnings
74 int GetSeverityIcon() const;
80 wxArrayString m_aMessages
; // the log message texts
81 wxArrayInt m_aSeverity
; // one of wxLOG_XXX values
82 wxArrayLong m_aTimes
; // the time of each message
83 bool m_bErrors
, // do we have any errors?
84 m_bWarnings
, // any warnings?
85 m_bHasMessages
; // any messages at all?
88 // this method is called to show a single log message, it uses
89 // wxMessageBox() by default
90 virtual void DoShowSingleLogMessage(const wxString
& message
,
91 const wxString
& title
,
94 // this method is called to show multiple log messages, it uses wxLogDialog
95 virtual void DoShowMultipleLogMessages(const wxArrayString
& messages
,
96 const wxArrayInt
& severities
,
97 const wxArrayLong
& times
,
98 const wxString
& title
,
102 #endif // wxUSE_LOGGUI
104 // ----------------------------------------------------------------------------
105 // (background) log window: this class forwards all log messages to the log
106 // target which was active when it was instantiated, but also collects them
107 // to the log window. This window has its own menu which allows the user to
108 // close it, clear the log contents or save it to the file.
109 // ----------------------------------------------------------------------------
113 class WXDLLIMPEXP_CORE wxLogWindow
: public wxLogPassThrough
116 wxLogWindow(wxWindow
*pParent
, // the parent frame (can be NULL)
117 const wxString
& szTitle
, // the title of the frame
118 bool bShow
= true, // show window immediately?
119 bool bPassToOld
= true); // pass messages to the old target?
121 virtual ~wxLogWindow();
124 // show/hide the log window
125 void Show(bool bShow
= true);
126 // retrieve the pointer to the frame
127 wxFrame
*GetFrame() const;
130 // called immediately after the log frame creation allowing for
131 // any extra initializations
132 virtual void OnFrameCreate(wxFrame
*frame
);
133 // called if the user closes the window interactively, will not be
134 // called if it is destroyed for another reason (such as when program
135 // exits) - return true from here to allow the frame to close, false
136 // to prevent this from happening
137 virtual bool OnFrameClose(wxFrame
*frame
);
138 // called right before the log frame is going to be deleted: will
139 // always be called unlike OnFrameClose()
140 virtual void OnFrameDelete(wxFrame
*frame
);
143 virtual void DoLogTextAtLevel(wxLogLevel level
, const wxString
& msg
);
146 wxLogFrame
*m_pLogFrame
; // the log frame
148 wxDECLARE_NO_COPY_CLASS(wxLogWindow
);
151 #endif // wxUSE_LOGWINDOW
155 #endif // _WX_LOGG_H_