loudmouth/lm-debug.c
author Mikael Hallendal <micke@imendio.com>
Sun, 29 Apr 2007 22:09:44 +0200
changeset 265 ebfc8419758d
parent 99 81e9d035de02
child 213 27567fb5d37b
permissions -rw-r--r--
Bumped the version to 1.2.2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
     1
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
     2
/*
99
81e9d035de02 2004-10-05 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 84
diff changeset
     3
 * Copyright (C) 2003 Imendio AB
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
     4
 *
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
     5
 * This program is free software; you can redistribute it and/or
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
     6
 * modify it under the terms of the GNU Lesser General Public License as
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
     7
 * published by the Free Software Foundation; either version 2 of the
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
     8
 * License, or (at your option) any later version.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
     9
 *
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    10
 * This program is distributed in the hope that it will be useful,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    13
 * Lesser General Public License for more details.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    14
 *
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    15
 * You should have received a copy of the GNU Lesser General Public
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    16
 * License along with this program; if not, write to the
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    17
 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    18
 * Boston, MA 02111-1307, USA.
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    19
 */
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    20
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    21
#include "lm-debug.h"
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    22
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    23
#ifndef LM_NO_DEBUG
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    24
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    25
static LmLogLevelFlags debug_flags = 0;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    26
static gboolean initialized = FALSE;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    27
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    28
static const GDebugKey debug_keys[] = {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    29
	{"VERBOSE",      LM_LOG_LEVEL_VERBOSE},
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    30
	{"NET",          LM_LOG_LEVEL_NET},
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    31
	{"PARSER",       LM_LOG_LEVEL_PARSER},
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    32
	{"ALL",          LM_LOG_LEVEL_ALL}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    33
};
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    34
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    35
#define NUM_DEBUG_KEYS (sizeof (debug_keys) / sizeof (GDebugKey))
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    36
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    37
static void
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    38
debug_log_handler (const gchar    *log_domain,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    39
		   GLogLevelFlags  log_level,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    40
		   const gchar    *message,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    41
		   gpointer        user_data)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    42
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    43
	if (debug_flags & log_level) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    44
		if (log_level & LM_LOG_LEVEL_VERBOSE) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    45
			g_print ("*** ");
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    46
		}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    47
		else if (log_level & LM_LOG_LEVEL_PARSER) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    48
			g_print ("LM-PARSER: ");
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    49
		}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    50
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    51
		g_print ("%s", message);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    52
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    53
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    54
19
bb3195f74ac7 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 7
diff changeset
    55
/**
bb3195f74ac7 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 7
diff changeset
    56
 * lm_debug_init
bb3195f74ac7 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 7
diff changeset
    57
 *
bb3195f74ac7 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 7
diff changeset
    58
 * Initialized the debug system.
bb3195f74ac7 2003-07-17 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 7
diff changeset
    59
 **/
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    60
void 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    61
lm_debug_init (void)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    62
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    63
	const gchar *env_lm_debug;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    64
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    65
	if (initialized) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    66
		return;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    67
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    68
	
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    69
	env_lm_debug = g_getenv ("LM_DEBUG");
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    70
	if (env_lm_debug) {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    71
		debug_flags = g_parse_debug_string (env_lm_debug, debug_keys,
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    72
						    NUM_DEBUG_KEYS);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    73
	}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    74
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    75
	g_log_set_handler (LM_LOG_DOMAIN, LM_LOG_LEVEL_ALL, 
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    76
			   debug_log_handler, NULL);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    77
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    78
	initialized = TRUE;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    79
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    80
#endif /* LM_NO_DEBUG */
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    81