loudmouth/lm-debug.h
author Martyn Russell <martyn@imendio.com>
Thu, 28 Feb 2008 02:52:37 +0100
changeset 348 48fdfa327cc7
parent 255 704881ac7788
child 515 fb0f1adfa271
permissions -rw-r--r--
Make the 1.3 branch build with --disable-debug again. Fixes LM-113. committer: Mikael Hallendal <micke@imendio.com>
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
#ifndef __LM_DEBUG_H__
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    22
#define __LM_DEBUG_H__
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    23
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    24
#include <glib.h>
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    25
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    26
typedef enum {
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    27
	LM_LOG_LEVEL_VERBOSE = 1 << (G_LOG_LEVEL_USER_SHIFT),
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    28
	LM_LOG_LEVEL_NET     = 1 << (G_LOG_LEVEL_USER_SHIFT + 1),
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    29
	LM_LOG_LEVEL_PARSER  = 1 << (G_LOG_LEVEL_USER_SHIFT + 2),
213
27567fb5d37b Use g_warning and g_log for warnings and debug printouts in OpenSSL backend.
Mikael Hallendal <micke@imendio.com>
parents: 109
diff changeset
    30
	LM_LOG_LEVEL_SSL     = 1 << (G_LOG_LEVEL_USER_SHIFT + 3),
255
704881ac7788 Fixed potential problem if auth was not called from the open callback.
Mikael Hallendal <micke@imendio.com>
parents: 213
diff changeset
    31
	LM_LOG_LEVEL_SASL    = 1 << (G_LOG_LEVEL_USER_SHIFT + 4),
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    32
	LM_LOG_LEVEL_ALL     = (LM_LOG_LEVEL_NET |
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    33
				LM_LOG_LEVEL_VERBOSE |
213
27567fb5d37b Use g_warning and g_log for warnings and debug printouts in OpenSSL backend.
Mikael Hallendal <micke@imendio.com>
parents: 109
diff changeset
    34
				LM_LOG_LEVEL_PARSER |
255
704881ac7788 Fixed potential problem if auth was not called from the open callback.
Mikael Hallendal <micke@imendio.com>
parents: 213
diff changeset
    35
				LM_LOG_LEVEL_SSL |
704881ac7788 Fixed potential problem if auth was not called from the open callback.
Mikael Hallendal <micke@imendio.com>
parents: 213
diff changeset
    36
				LM_LOG_LEVEL_SASL)
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    37
} LmLogLevelFlags;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    38
109
c8ce6eaa3a4b 2005-03-31 Mikael Hallendal <micke@imendio.com>
hallski <hallski>
parents: 99
diff changeset
    39
#ifndef LM_LOG_DOMAIN
1
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    40
#  define LM_LOG_DOMAIN "LM"
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    41
#endif
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    42
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    43
#ifdef G_HAVE_ISO_VARARGS
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    44
#  ifdef LM_NO_DEBUG
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    45
#    define lm_verbose(...)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    46
#  else
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    47
#    define lm_verbose(...) \
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    48
       g_log (LM_LOG_DOMAIN, LM_LOG_LEVEL_VERBOSE, __VA_ARGS__)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    49
#  endif
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    50
#elif defined(G_HAVE_GNUC_VARARGS)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    51
#  if LM_NO_DEBUG
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    52
#    define lm_verbose(fmt...)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    53
#  else
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    54
#    define lm_verbose(fmt...) \
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    55
       g_log (LM_LOG_DOMAIN, LM_LOG_LEVEL_VERBOSE, fmt)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    56
#  endif
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    57
#else
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    58
#  if LM_NO_DEBUG
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    59
#    define lm_verbose(const gchar *format, ...) {};
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    60
#  else
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    61
static void
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    62
lm_verbose (const gchar *format, ...)
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    63
{
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    64
  va_list args;
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    65
  va_start (args, format);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    66
  g_logv (LM_LOG_DOMAIN, LM_LOG_LEVEL_VERBOSE, format, args);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    67
  va_end (args);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    68
}
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    69
#  endif
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    70
#endif
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    71
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    72
void lm_debug_init (void);
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    73
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    74
#endif /* __LM_DEBUG_H__ */
50e230cf7818 Initial revision
hallski <hallski>
parents:
diff changeset
    75