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 WXDLLEXPORT wxLogTextCtrl
: public wxLog
29 wxLogTextCtrl(wxTextCtrl
*pTextCtrl
);
32 // implement sink function
33 virtual void DoLogString(const wxChar
*szString
, time_t t
);
37 wxTextCtrl
*m_pTextCtrl
;
39 DECLARE_NO_COPY_CLASS(wxLogTextCtrl
)
42 #endif // wxUSE_TEXTCTRL
44 // ----------------------------------------------------------------------------
45 // GUI log target, the default one for wxWidgets programs
46 // ----------------------------------------------------------------------------
50 class WXDLLEXPORT wxLogGui
: public wxLog
56 // show all messages that were logged since the last Flush()
60 virtual void DoLog(wxLogLevel level
, const wxChar
*szString
, time_t t
);
65 wxArrayString m_aMessages
; // the log message texts
66 wxArrayInt m_aSeverity
; // one of wxLOG_XXX values
67 wxArrayLong m_aTimes
; // the time of each message
68 bool m_bErrors
, // do we have any errors?
69 m_bWarnings
, // any warnings?
70 m_bHasMessages
; // any messages at all?
74 #endif // wxUSE_LOGGUI
76 // ----------------------------------------------------------------------------
77 // (background) log window: this class forwards all log messages to the log
78 // target which was active when it was instantiated, but also collects them
79 // to the log window. This window has it's own menu which allows the user to
80 // close it, clear the log contents or save it to the file.
81 // ----------------------------------------------------------------------------
85 class WXDLLEXPORT wxLogWindow
: public wxLogPassThrough
88 wxLogWindow(wxWindow
*pParent
, // the parent frame (can be NULL)
89 const wxChar
*szTitle
, // the title of the frame
90 bool bShow
= true, // show window immediately?
91 bool bPassToOld
= true); // pass messages to the old target?
93 virtual ~wxLogWindow();
96 // show/hide the log window
97 void Show(bool bShow
= true);
98 // retrieve the pointer to the frame
99 wxFrame
*GetFrame() const;
102 // called immediately after the log frame creation allowing for
103 // any extra initializations
104 virtual void OnFrameCreate(wxFrame
*frame
);
105 // called if the user closes the window interactively, will not be
106 // called if it is destroyed for another reason (such as when program
107 // exits) - return true from here to allow the frame to close, false
108 // to prevent this from happening
109 virtual bool OnFrameClose(wxFrame
*frame
);
110 // called right before the log frame is going to be deleted: will
111 // always be called unlike OnFrameClose()
112 virtual void OnFrameDelete(wxFrame
*frame
);
115 virtual void DoLog(wxLogLevel level
, const wxChar
*szString
, time_t t
);
116 virtual void DoLogString(const wxChar
*szString
, time_t t
);
119 wxLogFrame
*m_pLogFrame
; // the log frame
121 DECLARE_NO_COPY_CLASS(wxLogWindow
)
124 #endif // wxUSE_LOGWINDOW
128 #endif // _WX_LOGG_H_