#ifndef _LOG_MYLOG_H_ #define _LOG_MYLOG_H_ #include #include #include #include #include #include #include #include using namespace std; #define RED "\x1B[31m" #define GRN "\x1B[32m" #define YEL "\x1B[33m" #define BLU "\x1B[34m" #define MAG "\x1B[35m" #define CYN "\x1B[36m" #define WHT "\x1B[37m" #define RESET "\x1B[0m" const int log_never=0; const int log_fatal=1; const int log_error=2; const int log_warn=3; const int log_info=4; const int log_debug=5; const int log_trace=6; const int log_end=7; const char log_text[][20]={"NEVER","FATAL","ERROR","WARN","INFO","DEBUG","TRACE",""}; const char log_color[][20]={RED,RED,RED,YEL,GRN,MAG,""}; extern int log_level; extern int enable_log_position; extern int enable_log_color; #ifdef MY_DEBUG #define mylog(__first_argu__dummy_abcde__,...) printf(__VA_ARGS__) #else #define mylog(...) log0(__FILE__,__FUNCTION__,__LINE__,__VA_ARGS__) #endif //#define mylog(__first_argu__dummy_abcde__,...) {;} void log0(const char * file,const char * function,int line,int level,const char* str, ...); void log_bare(int level,const char* str, ...); #endif