]>
Commit | Line | Data |
---|---|---|
d14a1e28 RD |
1 | ///////////////////////////////////////////////////////////////////////////// |
2 | // Name: _log.i | |
3 | // Purpose: SWIG interface stuff for wxLog | |
4 | // | |
5 | // Author: Robin Dunn | |
6 | // | |
7 | // Created: 18-June-1999 | |
8 | // RCS-ID: $Id$ | |
9 | // Copyright: (c) 2003 by Total Control Software | |
10 | // Licence: wxWindows license | |
11 | ///////////////////////////////////////////////////////////////////////////// | |
12 | ||
13 | // Not a %module | |
14 | ||
15 | ||
16 | //--------------------------------------------------------------------------- | |
17 | %newgroup | |
18 | ||
19 | ||
20 | typedef unsigned long wxTraceMask; | |
21 | typedef unsigned long wxLogLevel; | |
22 | ||
23 | ||
24 | enum | |
25 | { | |
26 | wxLOG_FatalError, // program can't continue, abort immediately | |
27 | wxLOG_Error, // a serious error, user must be informed about it | |
28 | wxLOG_Warning, // user is normally informed about it but may be ignored | |
29 | wxLOG_Message, // normal message (i.e. normal output of a non GUI app) | |
30 | wxLOG_Status, // informational: might go to the status line of GUI app | |
31 | wxLOG_Info, // informational message (a.k.a. 'Verbose') | |
32 | wxLOG_Debug, // never shown to the user, disabled in release mode | |
33 | wxLOG_Trace, // trace messages are also only enabled in debug mode | |
34 | wxLOG_Progress, // used for progress indicator (not yet) | |
35 | wxLOG_User = 100, // user defined levels start here | |
36 | wxLOG_Max = 10000 | |
37 | }; | |
38 | ||
39 | #define wxTRACE_MemAlloc "memalloc" // trace memory allocation (new/delete) | |
40 | #define wxTRACE_Messages "messages" // trace window messages/X callbacks | |
41 | #define wxTRACE_ResAlloc "resalloc" // trace GDI resource allocation | |
42 | #define wxTRACE_RefCount "refcount" // trace various ref counting operations | |
43 | #define wxTRACE_OleCalls "ole" // OLE interface calls | |
44 | ||
45 | #define wxTraceMemAlloc 0x0001 // trace memory allocation (new/delete) | |
46 | #define wxTraceMessages 0x0002 // trace window messages/X callbacks | |
47 | #define wxTraceResAlloc 0x0004 // trace GDI resource allocation | |
48 | #define wxTraceRefCount 0x0008 // trace various ref counting operations | |
49 | #define wxTraceOleCalls 0x0100 // OLE interface calls | |
50 | ||
51 | //--------------------------------------------------------------------------- | |
52 | ||
53 | class wxLog | |
54 | { | |
55 | public: | |
56 | wxLog(); | |
214c4fbe | 57 | ~wxLog(); |
d14a1e28 RD |
58 | |
59 | // these functions allow to completely disable all log messages | |
60 | // is logging disabled now? | |
61 | static bool IsEnabled(); | |
62 | ||
63 | // change the flag state, return the previous one | |
a72f4631 | 64 | static bool EnableLogging(bool doIt = true); |
d14a1e28 RD |
65 | |
66 | // static sink function | |
67 | static void OnLog(wxLogLevel level, const wxChar *szString, time_t t); | |
68 | ||
69 | // message buffering | |
70 | // flush shows all messages if they're not logged immediately (FILE | |
71 | // and iostream logs don't need it, but wxGuiLog does to avoid showing | |
72 | // 17 modal dialogs one after another) | |
73 | virtual void Flush(); | |
74 | ||
75 | // flush the active target if any | |
76 | static void FlushActive(); | |
77 | ||
78 | // only one sink is active at each moment | |
79 | // get current log target, will call wxApp::CreateLogTarget() to | |
80 | // create one if none exists | |
81 | static wxLog *GetActiveTarget(); | |
82 | ||
214c4fbe RD |
83 | %disownarg( wxLog* pLogger ); |
84 | %newobject SetActiveTarget; | |
d14a1e28 RD |
85 | // change log target, pLogger may be NULL |
86 | static wxLog *SetActiveTarget(wxLog *pLogger); | |
214c4fbe RD |
87 | %cleardisown( wxLog* pLogger ); |
88 | ||
d14a1e28 RD |
89 | // suspend the message flushing of the main target until the next call |
90 | // to Resume() - this is mainly for internal use (to prevent wxYield() | |
91 | // from flashing the messages) | |
92 | static void Suspend(); | |
93 | ||
94 | // must be called for each Suspend()! | |
95 | static void Resume(); | |
96 | ||
97 | ||
98 | // verbose mode is activated by standard command-line '-verbose' | |
99 | // option | |
a72f4631 | 100 | static void SetVerbose(bool bVerbose = true); |
d14a1e28 RD |
101 | |
102 | // Set log level. Log messages with level > logLevel will not be logged. | |
103 | static void SetLogLevel(wxLogLevel logLevel); | |
104 | ||
105 | // should GetActiveTarget() try to create a new log object if the | |
106 | // current is NULL? | |
107 | static void DontCreateOnDemand(); | |
108 | ||
6aaca5ba RD |
109 | // log the count of repeating messages instead of logging the messages |
110 | // multiple times | |
111 | static void SetRepetitionCounting(bool bRepetCounting = true); | |
112 | ||
113 | // gets duplicate counting status | |
114 | static bool GetRepetitionCounting(); | |
115 | ||
d14a1e28 RD |
116 | // trace mask (see wxTraceXXX constants for details) |
117 | static void SetTraceMask(wxTraceMask ulMask); | |
118 | ||
119 | // add string trace mask | |
120 | static void AddTraceMask(const wxString& str); | |
121 | ||
122 | // remove string trace mask | |
123 | static void RemoveTraceMask(const wxString& str); | |
124 | ||
125 | // remove all string trace masks | |
126 | static void ClearTraceMasks(); | |
127 | ||
128 | // get string trace masks | |
129 | static const wxArrayString &GetTraceMasks(); | |
130 | ||
131 | // sets the timestamp string: this is used as strftime() format string | |
132 | // for the log targets which add time stamps to the messages - set it | |
133 | // to NULL to disable time stamping completely. | |
134 | static void SetTimestamp(const wxChar *ts); | |
135 | ||
136 | ||
137 | // gets the verbose status | |
138 | static bool GetVerbose(); | |
139 | ||
140 | // get trace mask | |
141 | static wxTraceMask GetTraceMask(); | |
142 | ||
143 | // is this trace mask in the list? | |
144 | static bool IsAllowedTraceMask(const wxChar *mask); | |
145 | ||
146 | // return the current loglevel limit | |
147 | static wxLogLevel GetLogLevel(); | |
148 | ||
149 | ||
150 | // get the current timestamp format string (may be NULL) | |
151 | static const wxChar *GetTimestamp(); | |
152 | ||
153 | ||
154 | %extend { | |
155 | static wxString TimeStamp() { | |
156 | wxString msg; | |
157 | wxLog::TimeStamp(&msg); | |
158 | return msg; | |
159 | } | |
160 | } | |
161 | ||
4b5a79cf | 162 | %pythonPrepend Destroy "args[0].this.own(False)"; |
d14a1e28 RD |
163 | %extend { void Destroy() { delete self; } } |
164 | }; | |
165 | ||
166 | ||
167 | //--------------------------------------------------------------------------- | |
168 | ||
169 | ||
170 | class wxLogStderr : public wxLog | |
171 | { | |
172 | public: | |
173 | wxLogStderr(/* TODO: FILE *fp = (FILE *) NULL*/); | |
174 | }; | |
175 | ||
176 | ||
177 | class wxLogTextCtrl : public wxLog | |
178 | { | |
179 | public: | |
180 | wxLogTextCtrl(wxTextCtrl *pTextCtrl); | |
181 | }; | |
182 | ||
183 | ||
184 | class wxLogGui : public wxLog | |
185 | { | |
186 | public: | |
187 | wxLogGui(); | |
188 | }; | |
189 | ||
190 | class wxLogWindow : public wxLog | |
191 | { | |
192 | public: | |
193 | wxLogWindow(wxFrame *pParent, // the parent frame (can be NULL) | |
194 | const wxString& szTitle, // the title of the frame | |
a72f4631 RD |
195 | bool bShow = true, // show window immediately? |
196 | bool bPassToOld = true); // pass log messages to the old target? | |
d14a1e28 | 197 | |
a72f4631 | 198 | void Show(bool bShow = true); |
d14a1e28 RD |
199 | wxFrame *GetFrame() const; |
200 | wxLog *GetOldLog() const; | |
201 | bool IsPassingMessages() const; | |
202 | void PassMessages(bool bDoPass); | |
76b8fa1d RD |
203 | |
204 | %property(Frame, GetFrame, doc="See `GetFrame`"); | |
205 | %property(OldLog, GetOldLog, doc="See `GetOldLog`"); | |
d14a1e28 RD |
206 | }; |
207 | ||
208 | ||
209 | class wxLogChain : public wxLog | |
210 | { | |
211 | public: | |
212 | wxLogChain(wxLog *logger); | |
213 | void SetLog(wxLog *logger); | |
214 | void PassMessages(bool bDoPass); | |
215 | bool IsPassingMessages(); | |
216 | wxLog *GetOldLog(); | |
fe45b493 RD |
217 | void DetachOldLog(); |
218 | ||
76b8fa1d | 219 | %property(OldLog, GetOldLog, doc="See `GetOldLog`"); |
d14a1e28 RD |
220 | }; |
221 | ||
93649c2c RD |
222 | // log everything to a buffer |
223 | class wxLogBuffer : public wxLog | |
224 | { | |
225 | public: | |
226 | wxLogBuffer(); | |
227 | ||
228 | // get the string contents with all messages logged | |
76b8fa1d | 229 | const wxString& GetBuffer() const; |
93649c2c RD |
230 | |
231 | // show the buffer contents to the user in the best possible way (this uses | |
232 | // wxMessageOutputMessageBox) and clear it | |
233 | virtual void Flush(); | |
76b8fa1d RD |
234 | |
235 | %property(Buffer, GetBuffer, doc="See `GetBuffer`"); | |
93649c2c RD |
236 | }; |
237 | ||
d14a1e28 RD |
238 | |
239 | //--------------------------------------------------------------------------- | |
240 | ||
241 | unsigned long wxSysErrorCode(); | |
242 | const wxString wxSysErrorMsg(unsigned long nErrCode = 0); | |
4e819f10 | 243 | |
214c4fbe | 244 | %{// Make some wrappers that double any % signs so they are 'escaped' |
4e819f10 RD |
245 | void wxPyLogFatalError(const wxString& msg) |
246 | { | |
247 | wxString m(msg); | |
248 | m.Replace(wxT("%"), wxT("%%")); | |
249 | wxLogFatalError(m); | |
250 | } | |
251 | ||
252 | void wxPyLogError(const wxString& msg) | |
253 | { | |
254 | wxString m(msg); | |
255 | m.Replace(wxT("%"), wxT("%%")); | |
256 | wxLogError(m); | |
257 | } | |
258 | ||
259 | void wxPyLogWarning(const wxString& msg) | |
260 | { | |
261 | wxString m(msg); | |
262 | m.Replace(wxT("%"), wxT("%%")); | |
263 | wxLogWarning(m); | |
264 | } | |
265 | ||
266 | void wxPyLogMessage(const wxString& msg) | |
267 | { | |
268 | wxString m(msg); | |
269 | m.Replace(wxT("%"), wxT("%%")); | |
270 | wxLogMessage(m); | |
271 | } | |
272 | ||
273 | void wxPyLogInfo(const wxString& msg) | |
274 | { | |
275 | wxString m(msg); | |
276 | m.Replace(wxT("%"), wxT("%%")); | |
277 | wxLogInfo(m); | |
278 | } | |
279 | ||
280 | void wxPyLogDebug(const wxString& msg) | |
281 | { | |
282 | wxString m(msg); | |
283 | m.Replace(wxT("%"), wxT("%%")); | |
284 | wxLogDebug(m); | |
285 | } | |
286 | ||
287 | void wxPyLogVerbose(const wxString& msg) | |
288 | { | |
289 | wxString m(msg); | |
290 | m.Replace(wxT("%"), wxT("%%")); | |
291 | wxLogVerbose(m); | |
292 | } | |
293 | ||
294 | void wxPyLogStatus(const wxString& msg) | |
295 | { | |
296 | wxString m(msg); | |
297 | m.Replace(wxT("%"), wxT("%%")); | |
298 | wxLogStatus(m); | |
299 | } | |
300 | ||
301 | void wxPyLogStatusFrame(wxFrame *pFrame, const wxString& msg) | |
302 | { | |
303 | wxString m(msg); | |
304 | m.Replace(wxT("%"), wxT("%%")); | |
305 | wxLogStatus(pFrame, m); | |
306 | } | |
307 | ||
308 | void wxPyLogSysError(const wxString& msg) | |
309 | { | |
310 | wxString m(msg); | |
311 | m.Replace(wxT("%"), wxT("%%")); | |
312 | wxLogSysError(m); | |
313 | } | |
314 | ||
315 | void wxPyLogGeneric(unsigned long level, const wxString& msg) | |
316 | { | |
317 | wxString m(msg); | |
318 | m.Replace(wxT("%"), wxT("%%")); | |
319 | wxLogGeneric(level, m); | |
320 | } | |
321 | ||
322 | void wxPyLogTrace(unsigned long mask, const wxString& msg) | |
323 | { | |
324 | wxString m(msg); | |
325 | m.Replace(wxT("%"), wxT("%%")); | |
326 | wxLogTrace(mask, m); | |
327 | } | |
328 | ||
329 | void wxPyLogTrace(const wxString& mask, const wxString& msg) | |
330 | { | |
331 | wxString m(msg); | |
332 | m.Replace(wxT("%"), wxT("%%")); | |
333 | wxLogTrace(mask, m); | |
334 | } | |
335 | ||
336 | %} | |
337 | ||
1b8c7ba6 RD |
338 | %Rename(LogFatalError, void, wxPyLogFatalError(const wxString& msg)); |
339 | %Rename(LogError, void, wxPyLogError(const wxString& msg)); | |
340 | %Rename(LogWarning, void, wxPyLogWarning(const wxString& msg)); | |
341 | %Rename(LogMessage, void, wxPyLogMessage(const wxString& msg)); | |
342 | %Rename(LogInfo, void, wxPyLogInfo(const wxString& msg)); | |
343 | %Rename(LogDebug, void, wxPyLogDebug(const wxString& msg)); | |
344 | %Rename(LogVerbose, void, wxPyLogVerbose(const wxString& msg)); | |
345 | %Rename(LogStatus, void, wxPyLogStatus(const wxString& msg)); | |
346 | %Rename(LogStatusFrame, void, wxPyLogStatusFrame(wxFrame *pFrame, const wxString& msg)); | |
347 | %Rename(LogSysError, void, wxPyLogSysError(const wxString& msg)); | |
348 | ||
349 | %Rename(LogGeneric, void, wxPyLogGeneric(unsigned long level, const wxString& msg)); | |
4e819f10 RD |
350 | |
351 | %nokwargs wxPyLogTrace; | |
1b8c7ba6 RD |
352 | %Rename(LogTrace, void, wxPyLogTrace(unsigned long mask, const wxString& msg)); |
353 | %Rename(LogTrace, void, wxPyLogTrace(const wxString& mask, const wxString& msg)); | |
4e819f10 | 354 | |
d14a1e28 RD |
355 | |
356 | // wxLogFatalError helper: show the (fatal) error to the user in a safe way, | |
357 | // i.e. without using wxMessageBox() for example because it could crash | |
358 | void wxSafeShowMessage(const wxString& title, const wxString& text); | |
359 | ||
360 | ||
361 | ||
362 | // Suspress logging while an instance of this class exists | |
363 | class wxLogNull | |
364 | { | |
365 | public: | |
366 | wxLogNull(); | |
367 | ~wxLogNull(); | |
368 | }; | |
369 | ||
370 | ||
371 | ||
372 | //--------------------------------------------------------------------------- | |
373 | ||
374 | %{ | |
375 | // A wxLog class that can be derived from in wxPython | |
376 | class wxPyLog : public wxLog { | |
377 | public: | |
378 | wxPyLog() : wxLog() {} | |
379 | ||
380 | virtual void DoLog(wxLogLevel level, const wxChar *szString, time_t t) { | |
381 | bool found; | |
6e6b3557 | 382 | wxPyBlock_t blocked = wxPyBeginBlockThreads(); |
d14a1e28 RD |
383 | if ((found = wxPyCBH_findCallback(m_myInst, "DoLog"))) { |
384 | PyObject* s = wx2PyString(szString); | |
385 | wxPyCBH_callCallback(m_myInst, Py_BuildValue("(iOi)", level, s, t)); | |
386 | Py_DECREF(s); | |
387 | } | |
da32eb53 | 388 | wxPyEndBlockThreads(blocked); |
d14a1e28 RD |
389 | if (! found) |
390 | wxLog::DoLog(level, szString, t); | |
391 | } | |
392 | ||
393 | virtual void DoLogString(const wxChar *szString, time_t t) { | |
394 | bool found; | |
6e6b3557 | 395 | wxPyBlock_t blocked = wxPyBeginBlockThreads(); |
d14a1e28 RD |
396 | if ((found = wxPyCBH_findCallback(m_myInst, "DoLogString"))) { |
397 | PyObject* s = wx2PyString(szString); | |
398 | wxPyCBH_callCallback(m_myInst, Py_BuildValue("(Oi)", s, t)); | |
399 | Py_DECREF(s); | |
400 | } | |
da32eb53 | 401 | wxPyEndBlockThreads(blocked); |
d14a1e28 RD |
402 | if (! found) |
403 | wxLog::DoLogString(szString, t); | |
404 | } | |
405 | ||
a7a01418 | 406 | DEC_PYCALLBACK_VOID_(Flush); |
d14a1e28 RD |
407 | PYPRIVATE; |
408 | }; | |
a7a01418 | 409 | IMP_PYCALLBACK_VOID_(wxPyLog, wxLog, Flush); |
d14a1e28 RD |
410 | %} |
411 | ||
412 | // Now tell SWIG about it | |
413 | class wxPyLog : public wxLog { | |
414 | public: | |
c25f90f6 | 415 | %pythonAppend wxPyLog setCallbackInfo(PyLog) |
d14a1e28 RD |
416 | |
417 | wxPyLog(); | |
418 | ||
419 | void _setCallbackInfo(PyObject* self, PyObject* _class); | |
420 | }; | |
421 | ||
422 | //--------------------------------------------------------------------------- |