|
Evan@653
|
1 |
/** |
|
Evan@653
|
2 |
* Copyright (C) 2007-2008 Felipe Contreras |
|
Evan@653
|
3 |
* |
|
Evan@653
|
4 |
* This program is free software; you can redistribute it and/or modify |
|
Evan@653
|
5 |
* it under the terms of the GNU General Public License as published by |
|
Evan@653
|
6 |
* the Free Software Foundation; either version 2 of the License, or |
|
Evan@653
|
7 |
* (at your option) any later version. |
|
Evan@653
|
8 |
* |
|
Evan@653
|
9 |
* This program is distributed in the hope that it will be useful, |
|
Evan@653
|
10 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
Evan@653
|
11 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
Evan@653
|
12 |
* GNU General Public License for more details. |
|
Evan@653
|
13 |
* |
|
Evan@653
|
14 |
* You should have received a copy of the GNU General Public License |
|
Evan@653
|
15 |
* along with this program; if not, write to the Free Software |
|
Evan@653
|
16 |
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA |
|
Evan@653
|
17 |
*/ |
|
Evan@653
|
18 |
|
|
Evan@653
|
19 |
#ifndef PECAN_LOG_H |
|
Evan@653
|
20 |
#define PECAN_LOG_H |
|
Evan@653
|
21 |
|
|
Evan@653
|
22 |
#include <glib.h> |
|
Evan@653
|
23 |
#include "msn.h" |
|
Evan@653
|
24 |
|
|
Evan@653
|
25 |
#define PECAN_DEBUG |
|
Evan@653
|
26 |
|
|
Evan@653
|
27 |
#if defined(PECAN_DEBUG) |
|
Evan@653
|
28 |
|
|
Evan@653
|
29 |
/* #define PECAN_DEBUG_MSG */ |
|
Evan@653
|
30 |
/* #define PECAN_DEBUG_SLPMSG */ |
|
Evan@653
|
31 |
/* #define PECAN_DEBUG_HTTP */ |
|
Evan@653
|
32 |
|
|
Evan@653
|
33 |
/* #define PECAN_DEBUG_SLP_VERBOSE */ |
|
Evan@653
|
34 |
/* #define PECAN_DEBUG_SLP_FILES */ |
|
Evan@653
|
35 |
|
|
Evan@653
|
36 |
/* #define PECAN_DEBUG_NS */ |
|
Evan@653
|
37 |
/* #define PECAN_DEBUG_SB */ |
|
Evan@653
|
38 |
/* #define PECAN_DEBUG_DC */ |
|
Evan@653
|
39 |
|
|
Evan@653
|
40 |
/* #define PECAN_DEBUG_DC_FILES */ |
|
Evan@653
|
41 |
|
|
Evan@653
|
42 |
enum PecanLogLevel |
|
Evan@653
|
43 |
{ |
|
Evan@653
|
44 |
PECAN_LOG_LEVEL_NONE, |
|
Evan@653
|
45 |
PECAN_LOG_LEVEL_ERROR, |
|
Evan@653
|
46 |
PECAN_LOG_LEVEL_WARNING, |
|
Evan@653
|
47 |
PECAN_LOG_LEVEL_INFO, |
|
Evan@653
|
48 |
PECAN_LOG_LEVEL_DEBUG, |
|
Evan@653
|
49 |
PECAN_LOG_LEVEL_LOG |
|
Evan@653
|
50 |
}; |
|
Evan@653
|
51 |
|
|
Evan@653
|
52 |
typedef enum PecanLogLevel PecanLogLevel; |
|
Evan@653
|
53 |
|
|
Evan@653
|
54 |
void msn_base_log_helper (PecanLogLevel level, const gchar *file, const gchar *function, gint line, const gchar *fmt, ...); |
|
Evan@653
|
55 |
void msn_dump_file (const gchar *buffer, gsize len); |
|
Evan@653
|
56 |
|
|
Evan@653
|
57 |
#define pecan_print(...) g_print (__VA_ARGS__); |
|
Evan@653
|
58 |
|
|
Evan@653
|
59 |
#define msn_base_log(level, ...) msn_base_log_helper (level, __FILE__, __func__, __LINE__, __VA_ARGS__); |
|
Evan@653
|
60 |
|
|
Evan@653
|
61 |
#define pecan_error(...) msn_base_log (PECAN_LOG_LEVEL_ERROR, __VA_ARGS__); |
|
Evan@653
|
62 |
#define pecan_warning(...) msn_base_log (PECAN_LOG_LEVEL_WARNING, __VA_ARGS__); |
|
Evan@653
|
63 |
#define pecan_info(...) msn_base_log (PECAN_LOG_LEVEL_INFO, __VA_ARGS__); |
|
Evan@653
|
64 |
#define pecan_debug(...) msn_base_log (PECAN_LOG_LEVEL_DEBUG, __VA_ARGS__); |
|
Evan@653
|
65 |
#define pecan_log(...) msn_base_log (PECAN_LOG_LEVEL_LOG, __VA_ARGS__); |
|
Evan@653
|
66 |
|
|
Evan@653
|
67 |
#elif !defined(PECAN_DEBUG) |
|
Evan@653
|
68 |
|
|
Evan@653
|
69 |
#define pecan_print(...) {} |
|
Evan@653
|
70 |
#define pecan_error(...) {} |
|
Evan@653
|
71 |
#define pecan_warning(...) {} |
|
Evan@653
|
72 |
#define pecan_info(...) {} |
|
Evan@653
|
73 |
#define pecan_debug(...) {} |
|
Evan@653
|
74 |
#define pecan_log(...) {} |
|
Evan@653
|
75 |
#define msn_dump_file(...) {} |
|
Evan@653
|
76 |
|
|
Evan@653
|
77 |
#endif /* !defined(PECAN_DEBUG) */ |
|
Evan@653
|
78 |
|
|
Evan@653
|
79 |
#endif /* PECAN_LOG_H */ |