void zbx_strlog_alloc(int level, char **out, size_t *out_alloc, size_t *out_offset, const char *format,
#define LOG_LEVEL_EMPTY 0
#define LOG_LEVEL_WARNING 3
#define LOG_LEVEL_DEBUG 4
#define LOG_LEVEL_TRACE 5
#define LOG_LEVEL_INFORMATION 127
#define LOG_TYPE_UNDEFINED 0
#define LOG_TYPE_SYSTEM 1
#define LOG_TYPE_CONSOLE 3
#define ZBX_OPTION_LOGTYPE_SYSTEM "system"
#define ZBX_OPTION_LOGTYPE_FILE "file"
#define ZBX_OPTION_LOGTYPE_CONSOLE "console"
#define LOG_ENTRY_INTERVAL_DELAY 60
extern int zbx_log_level;
#define ZBX_CHECK_LOG_LEVEL(level) \
((LOG_LEVEL_INFORMATION != (level) && \
((level) > zbx_log_level || LOG_LEVEL_EMPTY == (level))) ? FAIL : SUCCEED)
# define ZBX_ZABBIX_LOG_CHECK
# define zabbix_log(level, ...) \
if (SUCCEED == ZBX_CHECK_LOG_LEVEL(level)) \
__zbx_zabbix_log(level, __VA_ARGS__); \
# define zabbix_log __zbx_zabbix_log