mirror of
https://github.com/cesanta/mongoose.git
synced 2025-01-23 10:54:16 +08:00
0ea3cdd228
Configured via `debug.std{out,err}_topic` PUBLISHED_FROM=66c581c38c5039aa9ecc406f8aac0b7e3c6541fc
79 lines
1.3 KiB
C
79 lines
1.3 KiB
C
/*
|
|
* Copyright (c) 2014-2016 Cesanta Software Limited
|
|
* All rights reserved
|
|
*/
|
|
|
|
#ifndef CS_COMMON_CS_DBG_H_
|
|
#define CS_COMMON_CS_DBG_H_
|
|
|
|
#if CS_ENABLE_STDIO
|
|
#include <stdio.h>
|
|
#endif
|
|
|
|
#ifndef CS_ENABLE_DEBUG
|
|
#define CS_ENABLE_DEBUG 0
|
|
#endif
|
|
|
|
#ifndef CS_LOG_ENABLE_TS_DIFF
|
|
#define CS_LOG_ENABLE_TS_DIFF 0
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif /* __cplusplus */
|
|
|
|
enum cs_log_level {
|
|
LL_NONE = -1,
|
|
LL_ERROR = 0,
|
|
LL_WARN = 1,
|
|
LL_INFO = 2,
|
|
LL_DEBUG = 3,
|
|
LL_VERBOSE_DEBUG = 4,
|
|
|
|
_LL_MIN = -2,
|
|
_LL_MAX = 5,
|
|
};
|
|
|
|
void cs_log_set_level(enum cs_log_level level);
|
|
|
|
#if CS_ENABLE_STDIO
|
|
|
|
void cs_log_set_file(FILE *file);
|
|
|
|
extern enum cs_log_level cs_log_threshold;
|
|
void cs_log_print_prefix(const char *func);
|
|
void cs_log_printf(const char *fmt, ...);
|
|
|
|
#define LOG(l, x) \
|
|
if (cs_log_threshold >= l) { \
|
|
cs_log_print_prefix(__func__); \
|
|
cs_log_printf x; \
|
|
}
|
|
|
|
#ifndef CS_NDEBUG
|
|
|
|
#define DBG(x) \
|
|
if (cs_log_threshold >= LL_VERBOSE_DEBUG) { \
|
|
cs_log_print_prefix(__func__); \
|
|
cs_log_printf x; \
|
|
}
|
|
|
|
#else /* NDEBUG */
|
|
|
|
#define DBG(x)
|
|
|
|
#endif
|
|
|
|
#else /* CS_ENABLE_STDIO */
|
|
|
|
#define LOG(l, x)
|
|
#define DBG(x)
|
|
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif /* __cplusplus */
|
|
|
|
#endif /* CS_COMMON_CS_DBG_H_ */
|