// Simple C logging utility based off of https://github.com/rxi/log.c #ifndef LOGGER_H #define LOGGER_H enum { LOG_TRACE, LOG_DEBUG, LOG_INFO, LOG_WARN, LOG_ERROR, LOG_FATAL }; // can be modified to control log output int LOGGER_LOG_LEVEL; FILE *LOGGER_LOG_STREAM; void logger_init(int log_level, FILE *stream); #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__) void log_log(int level, const char *file, int line, const char *fmt, ...); #endif