Added a Win32/Win64 compliant implementation of vasprintf
* debug.c - C. Watford (christopher dot watford at gmail dot com)
Removed usage of vsyslog on Win32/Win64 systems, needs to be handled
by a configure script
* json_object.c - C. Watford (christopher dot watford at gmail dot com)
Added scope operator to wrap usage of json_object_object_foreach, this
needs to be rethought to be more ANSI C friendly
* json_object.h - C. Watford (christopher dot watford at gmail dot com)
Added Microsoft C friendly version of json_object_object_foreach
* json_tokener.c - C. Watford (christopher dot watford at gmail dot com)
Added a Win32/Win64 compliant implementation of strndup
* json_util.c - C. Watford (christopher dot watford at gmail dot com)
Added cast and mask to suffice size_t v. unsigned int conversion
correctness
* json_tokener.c - sign reversal issue on error info for nested object parse
spotted by Johan Bj�rklund (johbjo09 at kth.se)
* json_object.c - escape " in json_escape_str
* Change to automake and libtool to build shared and static library
Michael Clark <michael@metaparadigm.com>
git-svn-id: http://svn.metaparadigm.com/svn/json-c/trunk@4 327403b1-1117-474d-bef2-5cb71233fd97
102 lines
1.9 KiB
C
102 lines
1.9 KiB
C
/*
|
|
* $Id: debug.c,v 1.4 2005/06/14 22:41:51 mclark Exp $
|
|
*
|
|
* 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/
|
|
*
|
|
*/
|
|
|
|
#include "config.h"
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <stdarg.h>
|
|
|
|
#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
|
|
#include <sys/param.h>
|
|
#endif /* HAVE_SYS_PARAM_H */
|
|
|
|
#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);
|
|
#if HAVE_VSYSLOG
|
|
if(_syslog) {
|
|
vsyslog(LOG_ERR, msg, ap);
|
|
} else
|
|
#endif
|
|
vprintf(msg, ap);
|
|
exit(1);
|
|
}
|
|
|
|
|
|
void mc_debug(const char *msg, ...)
|
|
{
|
|
va_list ap;
|
|
if(_debug) {
|
|
va_start(ap, msg);
|
|
#if HAVE_VSYSLOG
|
|
if(_syslog) {
|
|
vsyslog(LOG_DEBUG, msg, ap);
|
|
} else
|
|
#endif
|
|
vprintf(msg, ap);
|
|
}
|
|
}
|
|
|
|
void mc_error(const char *msg, ...)
|
|
{
|
|
va_list ap;
|
|
va_start(ap, msg);
|
|
#if HAVE_VSYSLOG
|
|
if(_syslog) {
|
|
vsyslog(LOG_ERR, msg, ap);
|
|
} else
|
|
#endif
|
|
vfprintf(stderr, msg, ap);
|
|
}
|
|
|
|
void mc_info(const char *msg, ...)
|
|
{
|
|
va_list ap;
|
|
va_start(ap, msg);
|
|
#if HAVE_VSYSLOG
|
|
if(_syslog) {
|
|
vsyslog(LOG_INFO, msg, ap);
|
|
} else
|
|
#endif
|
|
vfprintf(stderr, msg, ap);
|
|
}
|