#ifndef __LOGGER_H_ #define __LOGGER_H_ #ifdef __cplusplus extern "C" { #endif #include void log_init(); void log_deinit(void); void log_print(const char *str); void log_printf(const char *format, ...); void OSFatal_printf(const char *format, ...); #define __FILENAME_X__ (strrchr(__FILE__, '\\') ? strrchr(__FILE__, '\\') + 1 : __FILE__) #define __FILENAME__ (strrchr(__FILE__, '/') ? strrchr(__FILE__, '/') + 1 : __FILENAME_X__) #define OSFATAL_FUNCTION_LINE(FMT, ARGS...) \ do { \ OSFatal_printf("[%s]%s@L%04d: " FMT "", __FILENAME__, __FUNCTION__, __LINE__, ##ARGS); \ } while (0) #define DEBUG_FUNCTION_LINE(FMT, ARGS...) \ do { \ log_printf("[%23s]%30s@L%04d: " FMT "", __FILENAME__, __FUNCTION__, __LINE__, ##ARGS); \ } while (0) #define DEBUG_FUNCTION_LINE_VERBOSE(FMT, ARGS...) \ do { \ log_printf("[%23s]%30s@L%04d: " FMT "", __FILENAME__, __FUNCTION__, __LINE__, ##ARGS); \ } while (0) #ifdef __cplusplus } #endif #endif