1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- #ifndef LOG_H
- #define LOG_H
- #include <stdio.h>
- #include <stdarg.h>
- #include <stdbool.h>
- #include <time.h>
- /*
- * ABLOG_KEEP_HOURS
- * 本程序(DC)运行日志保留时间,缺省120小时(5天)
- * ABLOG_STDOUT
- * 是否输出到标准输出,0 不输出, 缺省为 1 输出
- * ABLOG_FILE
- * 本程序(DC)运行日志输出文件
- * 如果不指定输出文件,日志信息会输出到标准输出(忽略ABLOG_STDOUT指定)
- * 文件名支持时间模式替换,自动修正参数给定的文件名中的替换标记
- * 模式中可以替换内容包括:
- * [PID] 用当前进程id
- * [YYYY] 虚拟当前时间的年
- * [yyyy] 系统当前时间的年
- * [MM] 虚拟当前时间的月
- * [mm] 系统当前时间的月
- * [DD] 虚拟当前时间的日
- * [dd] 系统当前时间的日
- * [HH] 虚拟当前时间的时
- * [hh] 系统当前时间的时
- * [MI] 虚拟当前时间的分
- * [mi] 系统当前时间的分
- * ABLOG_CLASS
- * 本程序(DC)运行日志输出内容,由下列标识文字用逗号分隔组合而成,如"Error,Metrics"
- * All 缺省,全部信息
- * Error 程序运行错误信息
- * Metrics 程序运行过程重要提示信息
- * State 程序运行状态提示信息
- * Detail 程序运行详细信息
- * Flow 程序运行流程
- * Flow_Public 公共的程序运行流程
- * Flow_Private 私有的程序运行流程
- * Flow_Restricted 受限的程序运行流程
- * Flow_Minor 次要的程序运行流程
- *
- */
- #define LOG_VERSION "0.1.0"
- typedef struct {
- va_list ap;
- const char *fmt;
- const char *file;
- struct tm *time;
- void *udata;
- int line;
- int level;
- } log_Event;
- typedef void (*log_LogFn)(log_Event *ev);
- typedef void (*log_LockFn)(bool lock, void *udata);
- enum { LOG_TRACE, LOG_DEBUG, LOG_INFO, LOG_WARN, LOG_ERROR, LOG_FATAL };
- #define log_trace(...) log_log(LOG_TRACE, __FILE__, __LINE__, __VA_ARGS__)
- #define log_debug(...) log_log(LOG_DEBUG, __FILE__, __LINE__, __VA_ARGS__)
- #define log_info(...) log_log(LOG_INFO, __FILE__, __LINE__, __VA_ARGS__)
- #define log_warn(...) log_log(LOG_WARN, __FILE__, __LINE__, __VA_ARGS__)
- #define log_error(...) log_log(LOG_ERROR, __FILE__, __LINE__, __VA_ARGS__)
- #define log_fatal(...) log_log(LOG_FATAL, __FILE__, __LINE__, __VA_ARGS__)
- const char* log_level_string(int level);
- void log_set_lock(log_LockFn fn, void *udata);
- void log_set_level(int level);
- void log_set_quiet(bool enable);
- int log_add_callback(log_LogFn fn, void *udata, int level);
- int log_add_fp(FILE *fp, int level);
- void log_log(int level, const char *file, int line, const char *fmt, ...);
- #endif
|