comparison src/protocols/sametime/meanwhile/mw_debug.h @ 10969:3ef77720e577

[gaim-migrate @ 12790] importing meanwhile library for use in the sametime plugin committer: Tailor Script <tailor@pidgin.im>
author Christopher O'Brien <siege@pidgin.im>
date Sun, 05 Jun 2005 02:50:13 +0000
parents
children 0110fc7c6a8a
comparison
equal deleted inserted replaced
10968:e0d5038fbb7e 10969:3ef77720e577
1
2 /*
3 Meanwhile - Unofficial Lotus Sametime Community Client Library
4 Copyright (C) 2004 Christopher (siege) O'Brien
5
6 This library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Library General Public
8 License as published by the Free Software Foundation; either
9 version 2 of the License, or (at your option) any later version.
10
11 This library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Library General Public License for more details.
15
16 You should have received a copy of the GNU Library General Public
17 License along with this library; if not, write to the Free
18 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
19 */
20
21 #ifndef _MW_DEBUG_H
22 #define _MW_DEBUG_H
23
24
25 #include <stdarg.h>
26 #include <glib.h>
27
28 #include "mw_common.h"
29
30
31 /** replaces NULL strings with "(null)". useful for printf where
32 you're unsure that the %s will be non-NULL. Note that while the
33 linux printf will do this automatically, not all will. The others
34 will instead segfault */
35 #define NSTR(str) ((str)? (str): "(null)")
36
37
38 #ifndef g_debug
39 #define g_debug(format...) g_log(G_LOG_DOMAIN, G_LOG_LEVEL_DEBUG, format)
40 #endif
41
42
43 #ifndef g_info
44 #define g_info(format...) g_log(G_LOG_DOMAIN, G_LOG_LEVEL_INFO, format)
45 #endif
46
47
48 /** logs buf as hex pairs. Requires DEBUG enabled during build */
49 void pretty_print(const char *buf, gsize len);
50
51
52 /** logs block as hex pairs. Requires DEBUG enabled during build */
53 void pretty_print_opaque(struct mwOpaque *block);
54
55
56 #ifndef MW_MAILME_ADDRESS
57 /** email address used in mw_debug_mailme. */
58 #define MW_MAILME_ADDRESS "meanwhile-devel@lists.sourceforge.net"
59 #endif
60
61
62 #ifndef MW_MAILME_CUT_START
63 #define MW_MAILME_CUT_START "-------- begin copy --------"
64 #endif
65
66
67 #ifndef MW_MAILME_CUT_STOP
68 #define MW_MAILME_CUT_STOP "--------- end copy ---------"
69 #endif
70
71
72 #ifndef MW_MAILME_MESSAGE
73 /** message used in mw_debug_mailme instructing user on what to do
74 with the debugging output produced from that function */
75 #define MW_MAILME_MESSAGE "\n" \
76 " Greetings! It seems that you've run across protocol data that the\n" \
77 "Meanwhile library does not yet know about. As such, there may be\n" \
78 "some unexpected behaviour in this session. If you'd like to help\n" \
79 "resolve this issue, please copy and paste the following block into\n" \
80 "an email to the address listed below with a brief explanation of\n" \
81 "what you were doing at the time of this message. Thanks a lot!"
82 #endif
83
84
85 /** Outputs a hex dump of a mwOpaque with debugging info and a
86 pre-defined message. Identical to mw_debug_mailme, but taking a
87 va_list argument */
88 void mw_debug_mailme_v(struct mwOpaque *block,
89 const char *info, va_list args);
90
91
92 /** Outputs a hex dump of a mwOpaque with debugging info and a
93 pre-defined message.
94
95 @arg block data to be printed in a hex block
96 @arg info a printf-style format string
97
98 The resulting message is in the following format:
99 @code
100 MW_MAILME_MESSAGE
101 " Please send mail to: " MW_MAILME_ADDRESS
102 MW_MAILME_CUT_START
103 info
104 block
105 MW_MAILME_CUT_STOP
106 @endcode
107 */
108 void mw_debug_mailme(struct mwOpaque *block, const char *info, ...);
109
110
111 #endif
112