00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00031
00032 #ifndef __LOGGER_H__
00033 #define __LOGGER_H__
00034
00035 #include <stdio.h>
00036
00037 extern FILE *LOG_FILE;
00038
00039 void log_open(char *filename);
00040 void log_close();
00041
00042
00043 #define LOG_FLUSH 1
00044
00045 #ifdef LOG_ENABLED
00046
00047 #define log_info(format, ...) _log_info(format, ## __VA_ARGS__)
00048 #define log_warning(format, ...) _log_warning(format, ## __VA_ARGS__)
00049 #define log_error(format, ...) _log_error(format, ## __VA_ARGS__)
00050 #define log_js(format, ...) _log_js(format, ## __VA_ARGS__)
00051
00052 #ifdef DEBUG_LOG_ENABLED
00053 #define log_debug(format, ...) _log_debug(format, __FILE__, __LINE__, __func__, ## __VA_ARGS__)
00054 #define print_backtrace() _print_backtrace()
00055 #else
00056 #ifdef TOMBDEBUG
00057 #define log_debug(format, ...) _log_debug(format, __FILE__, __LINE__, __func__, ## __VA_ARGS__)
00058 #define print_backtrace() _print_backtrace()
00059 #else
00060 #define log_debug(format, ...)
00061 #define print_backtrace()
00062 #endif
00063 #endif
00064
00065 #else
00066
00067 #define log_info(format, ...)
00068 #define log_warning(format, ...)
00069 #define log_error(format, ...)
00070 #define log_js(format, ...)
00071 #define log_debug(format, ...)
00072 #define print_backtrace()
00073
00074 #endif
00075
00076
00077 void _log_info(const char *format, ...);
00078 void _log_warning(const char *format, ...);
00079 void _log_error(const char *format, ...);
00080 void _log_js(const char *format, ...);
00081 void _log_debug(const char *format, const char* file, int line, const char *function, ...);
00082 void _print_backtrace(FILE* file = LOG_FILE);
00083
00084 #endif // __LOGGER_H__