blob: f2dc5411e19c6424b512e238234ff175a36c678b [file] [log] [blame]
Michael Clarkf0d08882007-03-13 08:26:18 +00001/*
Michael Clark837240f2007-03-13 08:26:25 +00002 * $Id: debug.h,v 1.5 2006/01/30 23:07:57 mclark Exp $
Michael Clarkf0d08882007-03-13 08:26:18 +00003 *
Michael Clarkf6a6e482007-03-13 08:26:23 +00004 * Copyright (c) 2004, 2005 Metaparadigm Pte. Ltd.
Michael Clarkf0d08882007-03-13 08:26:18 +00005 * Michael Clark <michael@metaparadigm.com>
Keith Derrick74d830d2012-04-12 11:40:44 -07006 * Copyright (c) 2009 Hewlett-Packard Development Company, L.P.
Michael Clarkf0d08882007-03-13 08:26:18 +00007 *
Michael Clarkf6a6e482007-03-13 08:26:23 +00008 * This library is free software; you can redistribute it and/or modify
9 * it under the terms of the MIT license. See COPYING for details.
Michael Clarkf0d08882007-03-13 08:26:18 +000010 *
11 */
12
13#ifndef _DEBUG_H_
14#define _DEBUG_H_
15
Keith Derrick74d830d2012-04-12 11:40:44 -070016#include <stdlib.h>
17
Michael Clarkaaec1ef2009-02-25 02:31:32 +000018#ifdef __cplusplus
19extern "C" {
20#endif
21
Michael Clarkf0d08882007-03-13 08:26:18 +000022extern void mc_set_debug(int debug);
Michael Clark14862b12007-12-07 02:50:42 +000023extern int mc_get_debug(void);
Michael Clarkf0d08882007-03-13 08:26:18 +000024
25extern void mc_set_syslog(int syslog);
Eric Haszlakiewiczb3bce4d2013-06-29 15:31:18 -050026
27/**
28 * @deprecated Use mc_error(), and return an appropriate error.
29 */
Michael Clarkf0d08882007-03-13 08:26:18 +000030extern void mc_abort(const char *msg, ...);
31extern void mc_debug(const char *msg, ...);
32extern void mc_error(const char *msg, ...);
33extern void mc_info(const char *msg, ...);
34
Keith Derrick74d830d2012-04-12 11:40:44 -070035#ifndef __STRING
36#define __STRING(x) #x
37#endif
38
39#ifndef PARSER_BROKEN_FIXED
40
41#define JASSERT(cond) do {} while(0)
42
43#else
44
45#define JASSERT(cond) do { \
46 if (!(cond)) { \
47 mc_error("cjson assert failure %s:%d : cond \"" __STRING(cond) "failed\n", __FILE__, __LINE__); \
48 *(int *)0 = 1;\
49 abort(); \
50 }\
51 } while(0)
52
53#endif
54
Eric Haszlakiewiczb3bce4d2013-06-29 15:31:18 -050055/**
56 * @deprecated Use MC_ERROR(), and return an appropriate error.
57 */
Keith Derrick74d830d2012-04-12 11:40:44 -070058#define MC_ABORT(x, ...) mc_abort(x, ##__VA_ARGS__)
59#define MC_ERROR(x, ...) mc_error(x, ##__VA_ARGS__)
60
Michael Clarkdfaf6702007-10-25 02:26:00 +000061#ifdef MC_MAINTAINER_MODE
62#define MC_SET_DEBUG(x) mc_set_debug(x)
63#define MC_GET_DEBUG() mc_get_debug()
64#define MC_SET_SYSLOG(x) mc_set_syslog(x)
Michael Clarkdfaf6702007-10-25 02:26:00 +000065#define MC_DEBUG(x, ...) mc_debug(x, ##__VA_ARGS__)
Michael Clarkdfaf6702007-10-25 02:26:00 +000066#define MC_INFO(x, ...) mc_info(x, ##__VA_ARGS__)
67#else
68#define MC_SET_DEBUG(x) if (0) mc_set_debug(x)
69#define MC_GET_DEBUG() (0)
70#define MC_SET_SYSLOG(x) if (0) mc_set_syslog(x)
Michael Clarkdfaf6702007-10-25 02:26:00 +000071#define MC_DEBUG(x, ...) if (0) mc_debug(x, ##__VA_ARGS__)
Michael Clarkdfaf6702007-10-25 02:26:00 +000072#define MC_INFO(x, ...) if (0) mc_info(x, ##__VA_ARGS__)
73#endif
74
Michael Clarkaaec1ef2009-02-25 02:31:32 +000075#ifdef __cplusplus
76}
77#endif
78
Michael Clarkf0d08882007-03-13 08:26:18 +000079#endif