g_log() accelerated by 'captive_debug_messages_disabled' slave global flag.
[captive.git] / src / libcaptive / include / captive / config2.h
1 /* $Id$
2  * Supplemental include file for config.h of libcaptive
3  * Copyright (C) 2003 Jan Kratochvil <project-captive@jankratochvil.net>
4  * 
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation; exactly version 2 of June 1991 is required
8  * 
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  * 
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
17  */
18
19
20 #ifndef _CAPTIVE_CONFIG2_H
21 #define _CAPTIVE_CONFIG2_H 1
22
23
24 /* We need to redefine it here as any '#undef' in config.h gets commented
25  * out during 'config.h.in' -> 'config.h' pass.
26  */
27 #if defined(__GNUC__) && (__GNUC__ >= 3)
28 #include <glib/gmacros.h>       /* for 'G_STRLOC' */
29 #  undef  G_STRLOC
30 /* '__func__' does not string-concatenate! */
31 #  define G_STRLOC      __func__
32 #endif
33
34
35 /* g_log() and g_logv() acceleration */
36 #ifdef LIBCAPTIVE
37 #include <glib/gmessages.h>     /* for g_log() */
38 #include <glib/gtypes.h>        /* for 'gboolean' */
39 extern gboolean captive_debug_messages_disabled;
40 #define g_log(log_domain,log_level,format,args...) ({ \
41                 GLogLevelFlags _captive_g_log_log_level=(log_level); \
42                 if ((_captive_g_log_log_level&~(G_LOG_LEVEL_MESSAGE|G_LOG_LEVEL_INFO|G_LOG_LEVEL_DEBUG)) \
43                                 || !captive_debug_messages_disabled) \
44                         g_log((log_domain),_captive_g_log_log_level,(format) , ## args); \
45                 })
46 #define g_logv(log_domain,log_level,format,args) ({ \
47                 GLogLevelFlags _captive_g_logv_log_level=(log_level); \
48                 if ((_captive_g_logv_log_level&~(G_LOG_LEVEL_MESSAGE|G_LOG_LEVEL_INFO|G_LOG_LEVEL_DEBUG)) \
49                                 || !captive_debug_messages_disabled) \
50                         g_logv((log_domain),_captive_g_logv_log_level,(format),(args)); \
51                 })
52 #endif /* LIBCAPTIVE */
53
54
55 #endif /* _CAPTIVE_CONFIG2_H */