2 // This file is part of the aMule Project.
4 // Copyright (c) 2005-2011 aMule Team ( admin@amule.org / http://www.amule.org )
6 // Any parts of this program derived from the xMule, lMule or eMule project,
7 // or contributed by third-party developers are copyrighted by their
10 // This program is free software; you can redistribute it and/or modify
11 // it under the terms of the GNU General Public License as published by
12 // the Free Software Foundation; either version 2 of the License, or
13 // (at your option) any later version.
15 // This program is distributed in the hope that it will be useful,
16 // but WITHOUT ANY WARRANTY; without even the implied warranty of
17 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 // GNU General Public License for more details.
20 // You should have received a copy of the GNU General Public License
21 // along with this program; if not, write to the Free Software
22 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
35 //! Standard warning, not debug
37 //! General warnings/errors.
39 //! Warnings/Errors for the main hashing thread.
41 //! Warnings/Errors for client-objects.
43 //! Warnings/Errors for the local client protocol.
45 //! Warnings/Errors for the remote client protocol.
47 //! Warnings/Errors when parsing packets.
49 //! Warnings/Errors for the CFile class.
51 //! Warnings/Errors related to reading/writing files.
53 //! Warnings/Errors when using the zLib library.
55 //! Warnings/Errors for the AICH-syncronization thread.
57 //! Warnings/Errors for transfering AICH hash-sets.
59 //! Warnings/Errors when recovering with AICH.
61 //! Warnings/Errors for the CListenSocket class.
63 //! Warnings/Errors for Client-Credits.
65 //! Warnings/Errors for the client UDP socket.
67 //! Warnings/Errors for the download-queue.
69 //! Warnings/Errors for the IP-Filter.
71 //! Warnings/Errors for known-files.
73 //! Warnings/Errors for part-files.
75 //! Warnings/Errors for SHA-hashset creation.
77 //! Warnings/Errors for servers, server connections.
79 //! Warnings/Errors for proxy.
81 //! Warnings/Errors related to searching.
83 //! Warnings/Errors related to the server UDP socket.
85 //! Warning/Errors related to Kademlia UDP comunication on client
87 //! Warning/Errors related to Kademlia Search
89 //! Warning/Errors related to Kademlia Routing
91 //! Warning/Errors related to Kademlia Indexing
93 //! Warning/Errors related to Kademlia Main Thread
95 //! Warning/Errors related to Kademlia Preferences
97 //! Warnings/Errors related to partfile importer
99 //! Warnings/Errors related to the basic UDP socket-class.
101 //! Warnings/Errors related to the thread-scheduler.
103 //! Warnings/Errors related to the Universal Plug and Play subsystem.
105 //! Warnings/Errors related to the UDP Firewall Tester
107 //! Warnings/Errors related to Kad packet tracking.
108 logKadPacketTracking
,
109 //! Warnings/Errors related to Kad entry tracking.
111 //! Full log of external connection packets
113 //! Warnings/Errors related to HTTP traffic
115 //! Warnings/Errors related to Boost Asio networking
117 // IMPORTANT NOTE: when you add values to this enum, update the g_debugcats
118 // array in Logger.cpp!
124 * Container-class for the debugging categories.
132 * @param type The actual debug-category type.
133 * @param name The user-readable name.
135 CDebugCategory( DebugType type
, const wxString
& name
)
136 : m_name(name
), m_type(type
), m_enabled(false)
141 * Returns true if the category is enabled.
143 bool IsEnabled() const { return m_enabled
; }
146 * Enables/Disables the category.
148 void SetEnabled( bool enabled
) { m_enabled
= enabled
; }
152 * Returns the user-readable name.
154 const wxString
& GetName() const { return m_name
; }
157 * Returns the actual type.
159 DebugType
GetType() const { return m_type
; }
162 //! The user-readable name.
166 //! Whenever or not the category is enabled.
172 * Functions for logging operations.
174 class CLogger
: public wxEvtHandler
178 * Returns true if debug-messages should be generated for a specific category.
181 bool IsEnabled( DebugType
) const;
183 bool IsEnabled( DebugType
) const { return false; }
187 * Enables or disables debug-messages for a specific category.
189 void SetEnabled( DebugType type
, bool enabled
);
192 * Returns true if logging to stdout is enabled
194 bool IsEnabledStdoutLog() const { return m_StdoutLog
; }
197 * Enables or disables logging to stdout.
199 void SetEnabledStdoutLog(bool enabled
) { m_StdoutLog
= enabled
; }
203 * Logs the specified line of text, prefixed with the name of the DebugType.
204 * (except for logStandard)
208 * @param critical If true, then the message will be made visible directly to the user.
209 * @param type The debug-category, the name of which will be prepended to the line.
210 * @param str The actual line of text.
212 * This function is thread-safe. If it is called by the main thread, the
213 * event will be sent directly to the application, otherwise it will be
214 * queued in the event-loop.
217 const wxString
&file
,
222 bool toStdout
= false,
227 const wxString
&file
,
231 const std::ostringstream
&msg
);
234 const wxString
&file
,
237 const std::ostringstream
&msg
);
241 * Emergency log for crashes.
243 void EmergencyLog(const wxString
&message
, bool closeLog
= true);
246 * Returns a category specified by index.
248 const CDebugCategory
& GetDebugCategory( int index
);
251 * Returns the number of debug-categories.
253 unsigned int GetDebugCategoryCount();
256 * Open Logfile, true on success
258 bool OpenLogfile(const wxString
& name
);
266 * Get name of Logfile
268 const wxString
& GetLogfileName() const {
269 return m_LogfileName
;
275 void OnLoggingEvent(class CLoggingEvent
& evt
);
287 class wxFFileOutputStream
* applog
; // the logfile
288 wxString m_LogfileName
;
289 wxString m_ApplogBuf
;
291 int m_count
; // output line counter
295 * Write all waiting log info to the logfile
300 * Really output a single line
302 void DoLine(const wxString
& line
, bool toStdout
, bool toGUI
);
305 * Really output several lines
307 void DoLines(const wxString
& lines
, bool critical
, bool toStdout
, bool toGUI
);
309 DECLARE_EVENT_TABLE()
312 extern CLogger theLogger
;
315 * This class forwards log-lines from wxWidgets to CLogger.
317 class CLoggerTarget
: public wxLog
323 * @see wxLog::DoLogString
325 #if wxCHECK_VERSION(2, 9, 0)
326 void DoLogText(const wxString
&msg
);
328 void DoLogString(const wxChar
*msg
, time_t);
333 DECLARE_LOCAL_EVENT_TYPE(MULE_EVT_LOGLINE
, -1)
336 /** This event is sent when a log-line is queued. */
337 class CLoggingEvent
: public wxEvent
340 CLoggingEvent(bool critical
, bool toStdout
, bool toGUI
, const wxString
& msg
)
341 : wxEvent(-1, MULE_EVT_LOGLINE
)
342 , m_critical(critical
)
345 // Deep copy, to avoid thread-unsafe reference counting. */
346 , m_msg(msg
.c_str(), msg
.Length())
350 const wxString
& Message() const {
354 bool IsCritical() const {
358 bool ToStdout() const {
366 wxEvent
* Clone() const {
367 return new CLoggingEvent(m_critical
, m_stdout
, m_GUI
, m_msg
);
378 typedef void (wxEvtHandler::*MuleLogEventFunction
)(CLoggingEvent
&);
380 //! Event-handler for completed hashings of new shared files and partfiles.
381 #define EVT_MULE_LOGGING(func) \
382 DECLARE_EVENT_TABLE_ENTRY(MULE_EVT_LOGLINE, -1, -1, \
383 (wxObjectEventFunction) (wxEventFunction) \
384 wxStaticCastEvent(MuleLogEventFunction, &func), (wxObject*) NULL),
387 // access the logfile for EC
391 class wxFFileInputStream
* m_logfile
;
392 class wxCharBuffer
* m_buffer
;
399 // construct/destruct
404 // Reset (used when logfile is cleared)
408 // get a String (if there is one)
410 bool GetString(wxString
& s
);
412 // is a String available ?
419 * These macros should be used when logging. The
420 * AddLogLineM macro will simply call one of the
421 * two CLogger::AddLogLine functions depending on
422 * parameters, but AddDebugLogLine* will only log
423 * a message if the message is either critical or
424 * the specified debug-type is enabled in the
426 * AddLogLineMS will also always print to stdout.
429 #define AddDebugLogLineN(...) do {} while (false)
430 #define AddLogLineN(...) do {} while (false)
431 #define AddLogLineNS(...) do {} while (false)
432 #define AddDebugLogLineC(...) do {} while (false)
433 #define AddLogLineC(...) do {} while (false)
434 #define AddLogLineCS(...) do {} while (false)
436 // Macro for UPnP. This is not a debug macro, but wants its category printed nevertheless (sigh).
437 #define AddLogLineU(critical, type, string) theLogger.AddLogLine(__TFILE__, __LINE__, critical, type, string)
438 // Macros for 'N'on critical logging
440 #define AddDebugLogLineN(type, string) if (theLogger.IsEnabled(type)) theLogger.AddLogLine(__TFILE__, __LINE__, false, type, string)
442 #define AddDebugLogLineN(type, string) do {} while (false)
444 #define AddLogLineN(string) theLogger.AddLogLine(__TFILE__, __LINE__, false, logStandard, string)
445 #define AddLogLineNS(string) theLogger.AddLogLine(__TFILE__, __LINE__, false, logStandard, string, true)
446 // Macros for 'C'ritical logging
447 #define AddDebugLogLineC(type, string) theLogger.AddLogLine(__TFILE__, __LINE__, true, type, string)
448 #define AddLogLineC(string) theLogger.AddLogLine(__TFILE__, __LINE__, true, logStandard, string)
449 #define AddLogLineCS(string) theLogger.AddLogLine(__TFILE__, __LINE__, true, logStandard, string, true)
450 // Macros for logging to logfile only
452 #define AddDebugLogLineF(type, string) if (theLogger.IsEnabled(type)) theLogger.AddLogLine(__TFILE__, __LINE__, false, type, string, false, false)
454 #define AddDebugLogLineF(type, string) do {} while (false)
456 #define AddLogLineF(string) theLogger.AddLogLine(__TFILE__, __LINE__, false, logStandard, string, false, false)
460 // File_checked_for_headers