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 // ----------------------------------------------------------------------------
18 // the following log targets are only compiled in if the we're compiling the
19 // GUI part (andnot just the base one) of the library, they're implemented in
20 // src/generic/logg.cpp *and not src/common/log.cpp unlike all the rest)
21 // ----------------------------------------------------------------------------
25 // log everything to a text window (GUI only of course)
26 class WXDLLIMPEXP_CORE wxLogTextCtrl
: public wxLog
29 wxLogTextCtrl(wxTextCtrl
*pTextCtrl
);
32 // implement sink function
33 virtual void DoLogString(const wxString
& szString
, time_t t
);
35 wxSUPPRESS_DOLOGSTRING_HIDE_WARNING()
39 wxTextCtrl
*m_pTextCtrl
;
41 DECLARE_NO_COPY_CLASS(wxLogTextCtrl
)
44 #endif // wxUSE_TEXTCTRL
46 // ----------------------------------------------------------------------------
47 // GUI log target, the default one for wxWidgets programs
48 // ----------------------------------------------------------------------------
52 class WXDLLIMPEXP_CORE wxLogGui
: public wxLog
58 // show all messages that were logged since the last Flush()
62 virtual void DoLog(wxLogLevel level
, const wxString
& szString
, time_t t
);
64 wxSUPPRESS_DOLOG_HIDE_WARNING()
66 // return the title to be used for the log dialog, depending on m_bErrors
67 // and m_bWarnings values
68 wxString
GetTitle() const;
70 // return the icon (one of wxICON_XXX constants) to be used for the dialog
71 // depending on m_bErrors/m_bWarnings
72 int GetSeverityIcon() const;
78 wxArrayString m_aMessages
; // the log message texts
79 wxArrayInt m_aSeverity
; // one of wxLOG_XXX values
80 wxArrayLong m_aTimes
; // the time of each message
81 bool m_bErrors
, // do we have any errors?
82 m_bWarnings
, // any warnings?
83 m_bHasMessages
; // any messages at all?
86 // this method is called to show a single log message, it uses
87 // wxMessageBox() by default
88 virtual void DoShowSingleLogMessage(const wxString
& message
,
89 const wxString
& title
,
92 // this method is called to show multiple log messages, it uses wxLogDialog
93 virtual void DoShowMultipleLogMessages(const wxArrayString
& messages
,
94 const wxArrayInt
& severities
,
95 const wxArrayLong
& times
,
96 const wxString
& title
,
100 #endif // wxUSE_LOGGUI
102 // ----------------------------------------------------------------------------
103 // (background) log window: this class forwards all log messages to the log
104 // target which was active when it was instantiated, but also collects them
105 // to the log window. This window has it's own menu which allows the user to
106 // close it, clear the log contents or save it to the file.
107 // ----------------------------------------------------------------------------
111 class WXDLLIMPEXP_CORE wxLogWindow
: public wxLogPassThrough
114 wxLogWindow(wxWindow
*pParent
, // the parent frame (can be NULL)
115 const wxString
& szTitle
, // the title of the frame
116 bool bShow
= true, // show window immediately?
117 bool bPassToOld
= true); // pass messages to the old target?
119 virtual ~wxLogWindow();
122 // show/hide the log window
123 void Show(bool bShow
= true);
124 // retrieve the pointer to the frame
125 wxFrame
*GetFrame() const;
128 // called immediately after the log frame creation allowing for
129 // any extra initializations
130 virtual void OnFrameCreate(wxFrame
*frame
);
131 // called if the user closes the window interactively, will not be
132 // called if it is destroyed for another reason (such as when program
133 // exits) - return true from here to allow the frame to close, false
134 // to prevent this from happening
135 virtual bool OnFrameClose(wxFrame
*frame
);
136 // called right before the log frame is going to be deleted: will
137 // always be called unlike OnFrameClose()
138 virtual void OnFrameDelete(wxFrame
*frame
);
141 virtual void DoLog(wxLogLevel level
, const wxString
& szString
, time_t t
);
142 virtual void DoLogString(const wxString
& szString
, time_t t
);
144 wxSUPPRESS_DOLOG_HIDE_WARNING()
145 wxSUPPRESS_DOLOGSTRING_HIDE_WARNING()
148 wxLogFrame
*m_pLogFrame
; // the log frame
150 DECLARE_NO_COPY_CLASS(wxLogWindow
)
153 #endif // wxUSE_LOGWINDOW
157 #endif // _WX_LOGG_H_