2007-03-13 08:26:18 +00:00
|
|
|
/*
|
2007-03-13 08:26:20 +00:00
|
|
|
* $Id: debug.c,v 1.4 2005/06/14 22:41:51 mclark Exp $
|
2007-03-13 08:26:18 +00:00
|
|
|
*
|
|
|
|
|
* Copyright Metaparadigm Pte. Ltd. 2004.
|
|
|
|
|
* Michael Clark <michael@metaparadigm.com>
|
|
|
|
|
*
|
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
|
* modify it under the terms of the GNU Lesser General Public (LGPL)
|
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
|
*
|
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
|
* Lesser General Public License for more details: http://www.gnu.org/
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
2007-03-13 08:26:20 +00:00
|
|
|
#include "config.h"
|
|
|
|
|
|
2007-03-13 08:26:18 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
#include <string.h>
|
|
|
|
|
#include <stdarg.h>
|
2007-03-13 08:26:20 +00:00
|
|
|
|
|
|
|
|
#if HAVE_SYSLOG_H
|
|
|
|
|
# include <syslog.h>
|
|
|
|
|
#endif /* HAVE_SYSLOG_H */
|
|
|
|
|
|
|
|
|
|
#if HAVE_UNISTD_H
|
|
|
|
|
# include <unistd.h>
|
|
|
|
|
#endif /* HAVE_UNISTD_H */
|
|
|
|
|
|
|
|
|
|
#if HAVE_SYS_PARAM_H
|
2007-03-13 08:26:18 +00:00
|
|
|
#include <sys/param.h>
|
2007-03-13 08:26:20 +00:00
|
|
|
#endif /* HAVE_SYS_PARAM_H */
|
2007-03-13 08:26:18 +00:00
|
|
|
|
|
|
|
|
#include "debug.h"
|
|
|
|
|
|
|
|
|
|
static int _syslog = 0;
|
|
|
|
|
static int _debug = 0;
|
|
|
|
|
|
|
|
|
|
void mc_set_debug(int debug) { _debug = debug; }
|
|
|
|
|
int mc_get_debug() { return _debug; }
|
|
|
|
|
|
|
|
|
|
extern void mc_set_syslog(int syslog)
|
|
|
|
|
{
|
|
|
|
|
_syslog = syslog;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void mc_abort(const char *msg, ...)
|
|
|
|
|
{
|
|
|
|
|
va_list ap;
|
|
|
|
|
va_start(ap, msg);
|
2007-03-13 08:26:20 +00:00
|
|
|
#if HAVE_VSYSLOG
|
|
|
|
|
if(_syslog) {
|
|
|
|
|
vsyslog(LOG_ERR, msg, ap);
|
|
|
|
|
} else
|
|
|
|
|
#endif
|
|
|
|
|
vprintf(msg, ap);
|
2007-03-13 08:26:18 +00:00
|
|
|
exit(1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void mc_debug(const char *msg, ...)
|
|
|
|
|
{
|
|
|
|
|
va_list ap;
|
|
|
|
|
if(_debug) {
|
|
|
|
|
va_start(ap, msg);
|
2007-03-13 08:26:20 +00:00
|
|
|
#if HAVE_VSYSLOG
|
|
|
|
|
if(_syslog) {
|
|
|
|
|
vsyslog(LOG_DEBUG, msg, ap);
|
|
|
|
|
} else
|
|
|
|
|
#endif
|
|
|
|
|
vprintf(msg, ap);
|
2007-03-13 08:26:18 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void mc_error(const char *msg, ...)
|
|
|
|
|
{
|
|
|
|
|
va_list ap;
|
|
|
|
|
va_start(ap, msg);
|
2007-03-13 08:26:20 +00:00
|
|
|
#if HAVE_VSYSLOG
|
|
|
|
|
if(_syslog) {
|
|
|
|
|
vsyslog(LOG_ERR, msg, ap);
|
|
|
|
|
} else
|
|
|
|
|
#endif
|
|
|
|
|
vfprintf(stderr, msg, ap);
|
2007-03-13 08:26:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void mc_info(const char *msg, ...)
|
|
|
|
|
{
|
|
|
|
|
va_list ap;
|
|
|
|
|
va_start(ap, msg);
|
2007-03-13 08:26:20 +00:00
|
|
|
#if HAVE_VSYSLOG
|
|
|
|
|
if(_syslog) {
|
|
|
|
|
vsyslog(LOG_INFO, msg, ap);
|
|
|
|
|
} else
|
|
|
|
|
#endif
|
|
|
|
|
vfprintf(stderr, msg, ap);
|
2007-03-13 08:26:18 +00:00
|
|
|
}
|