28 #ifndef _MISC_LOG_EX_H_
29 #define _MISC_LOG_EX_H_
35 #undef ELECTRONEUM_DEFAULT_LOG_CATEGORY
36 #define ELECTRONEUM_DEFAULT_LOG_CATEGORY "default"
38 #define MAX_LOG_FILE_SIZE 104850000
39 #define MAX_LOG_FILES 50
41 #define MCLOG_TYPE(level, cat, type, x) do { \
42 if (ELPP->vRegistry()->allowed(level, cat)) { \
43 el::base::Writer(level, __FILE__, __LINE__, ELPP_FUNC, type).construct(cat) << x; \
47 #define MCLOG(level, cat, x) MCLOG_TYPE(level, cat, el::base::DispatchAction::NormalLog, x)
48 #define MCLOG_FILE(level, cat, x) MCLOG_TYPE(level, cat, el::base::DispatchAction::FileOnlyLog, x)
50 #define MCFATAL(cat,x) MCLOG(el::Level::Fatal,cat, x)
51 #define MCERROR(cat,x) MCLOG(el::Level::Error,cat, x)
52 #define MCWARNING(cat,x) MCLOG(el::Level::Warning,cat, x)
53 #define MCINFO(cat,x) MCLOG(el::Level::Info,cat, x)
54 #define MCDEBUG(cat,x) MCLOG(el::Level::Debug,cat, x)
55 #define MCTRACE(cat,x) MCLOG(el::Level::Trace,cat, x)
57 #define MCLOG_COLOR(level,cat,color,x) MCLOG(level,cat,"\033[1;" color "m" << x << "\033[0m")
58 #define MCLOG_RED(level,cat,x) MCLOG_COLOR(level,cat,"31",x)
59 #define MCLOG_GREEN(level,cat,x) MCLOG_COLOR(level,cat,"32",x)
60 #define MCLOG_YELLOW(level,cat,x) MCLOG_COLOR(level,cat,"33",x)
61 #define MCLOG_BLUE(level,cat,x) MCLOG_COLOR(level,cat,"34",x)
62 #define MCLOG_MAGENTA(level,cat,x) MCLOG_COLOR(level,cat,"35",x)
63 #define MCLOG_CYAN(level,cat,x) MCLOG_COLOR(level,cat,"36",x)
65 #define MLOG_RED(level,x) MCLOG_RED(level,ELECTRONEUM_DEFAULT_LOG_CATEGORY,x)
66 #define MLOG_GREEN(level,x) MCLOG_GREEN(level,ELECTRONEUM_DEFAULT_LOG_CATEGORY,x)
67 #define MLOG_YELLOW(level,x) MCLOG_YELLOW(level,ELECTRONEUM_DEFAULT_LOG_CATEGORY,x)
68 #define MLOG_BLUE(level,x) MCLOG_BLUE(level,ELECTRONEUM_DEFAULT_LOG_CATEGORY,x)
69 #define MLOG_MAGENTA(level,x) MCLOG_MAGENTA(level,ELECTRONEUM_DEFAULT_LOG_CATEGORY,x)
70 #define MLOG_CYAN(level,x) MCLOG_CYAN(level,ELECTRONEUM_DEFAULT_LOG_CATEGORY,x)
72 #define MFATAL(x) MCFATAL(ELECTRONEUM_DEFAULT_LOG_CATEGORY,x)
73 #define MERROR(x) MCERROR(ELECTRONEUM_DEFAULT_LOG_CATEGORY,x)
74 #define MWARNING(x) MCWARNING(ELECTRONEUM_DEFAULT_LOG_CATEGORY,x)
75 #define MINFO(x) MCINFO(ELECTRONEUM_DEFAULT_LOG_CATEGORY,x)
76 #define MDEBUG(x) MCDEBUG(ELECTRONEUM_DEFAULT_LOG_CATEGORY,x)
77 #define MTRACE(x) MCTRACE(ELECTRONEUM_DEFAULT_LOG_CATEGORY,x)
78 #define MLOG(level,x) MCLOG(level,ELECTRONEUM_DEFAULT_LOG_CATEGORY,x)
80 #define MGINFO(x) MCINFO("global",x)
81 #define MGINFO_RED(x) MCLOG_RED(el::Level::Info, "global",x)
82 #define MGINFO_GREEN(x) MCLOG_GREEN(el::Level::Info, "global",x)
83 #define MGINFO_YELLOW(x) MCLOG_YELLOW(el::Level::Info, "global",x)
84 #define MGINFO_BLUE(x) MCLOG_BLUE(el::Level::Info, "global",x)
85 #define MGINFO_MAGENTA(x) MCLOG_MAGENTA(el::Level::Info, "global",x)
86 #define MGINFO_CYAN(x) MCLOG_CYAN(el::Level::Info, "global",x)
88 #define IFLOG(level, cat, type, init, x) \
90 if (ELPP->vRegistry()->allowed(level, cat)) { \
92 el::base::Writer(level, __FILE__, __LINE__, ELPP_FUNC, type).construct(cat) << x; \
95 #define MIDEBUG(init, x) IFLOG(el::Level::Debug, ELECTRONEUM_DEFAULT_LOG_CATEGORY, el::base::DispatchAction::NormalLog, init, x)
98 #define LOG_ERROR(x) MERROR(x)
99 #define LOG_PRINT_L0(x) MWARNING(x)
100 #define LOG_PRINT_L1(x) MINFO(x)
101 #define LOG_PRINT_L2(x) MDEBUG(x)
102 #define LOG_PRINT_L3(x) MTRACE(x)
103 #define LOG_PRINT_L4(x) MTRACE(x)
105 #define _dbg3(x) MTRACE(x)
106 #define _dbg2(x) MDEBUG(x)
107 #define _dbg1(x) MDEBUG(x)
108 #define _info(x) MINFO(x)
109 #define _note(x) MDEBUG(x)
110 #define _fact(x) MDEBUG(x)
111 #define _mark(x) MDEBUG(x)
112 #define _warn(x) MWARNING(x)
113 #define _erro(x) MERROR(x)
115 #define MLOG_SET_THREAD_NAME(x) el::Helpers::setThreadName(x)
119 #if (defined _MSC_VER)
120 #define LOCAL_ASSERT(expr) {if(epee::debug::get_set_enable_assert()){_ASSERTE(expr);}}
122 #define LOCAL_ASSERT(expr)
140 static bool e =
true;
149 #define ENDL std::endl
151 #define TRY_ENTRY() try {
152 #define CATCH_ENTRY(location, return_val) } \
153 catch(const std::exception& ex) \
156 LOG_ERROR("Exception at [" << location << "], what=" << ex.what()); \
161 LOG_ERROR("Exception at [" << location << "], generic exception \"...\"");\
165 #define CATCH_ENTRY_L0(lacation, return_val) CATCH_ENTRY(lacation, return_val)
166 #define CATCH_ENTRY_L1(lacation, return_val) CATCH_ENTRY(lacation, return_val)
167 #define CATCH_ENTRY_L2(lacation, return_val) CATCH_ENTRY(lacation, return_val)
168 #define CATCH_ENTRY_L3(lacation, return_val) CATCH_ENTRY(lacation, return_val)
169 #define CATCH_ENTRY_L4(lacation, return_val) CATCH_ENTRY(lacation, return_val)
172 #define ASSERT_MES_AND_THROW(message) {LOG_ERROR(message); std::stringstream ss; ss << message; throw std::runtime_error(ss.str());}
173 #define CHECK_AND_ASSERT_THROW_MES(expr, message) do {if(!(expr)) ASSERT_MES_AND_THROW(message);} while(0)
176 #ifndef CHECK_AND_ASSERT
177 #define CHECK_AND_ASSERT(expr, fail_ret_val) do{if(!(expr)){LOCAL_ASSERT(expr); return fail_ret_val;};}while(0)
180 #ifndef CHECK_AND_ASSERT_MES
181 #define CHECK_AND_ASSERT_MES(expr, fail_ret_val, message) do{if(!(expr)) {LOG_ERROR(message); return fail_ret_val;};}while(0)
184 #ifndef CHECK_AND_NO_ASSERT_MES_L
185 #define CHECK_AND_NO_ASSERT_MES_L(expr, fail_ret_val, l, message) do{if(!(expr)) {LOG_PRINT_L##l(message); return fail_ret_val;};}while(0)
188 #ifndef CHECK_AND_NO_ASSERT_MES
189 #define CHECK_AND_NO_ASSERT_MES(expr, fail_ret_val, message) CHECK_AND_NO_ASSERT_MES_L(expr, fail_ret_val, 0, message)
192 #ifndef CHECK_AND_NO_ASSERT_MES_L1
193 #define CHECK_AND_NO_ASSERT_MES_L1(expr, fail_ret_val, message) CHECK_AND_NO_ASSERT_MES_L(expr, fail_ret_val, 1, message)
197 #ifndef CHECK_AND_ASSERT_MES_NO_RET
198 #define CHECK_AND_ASSERT_MES_NO_RET(expr, message) do{if(!(expr)) {LOG_ERROR(message); return;};}while(0)
202 #ifndef CHECK_AND_ASSERT_MES2
203 #define CHECK_AND_ASSERT_MES2(expr, message) do{if(!(expr)) {LOG_ERROR(message); };}while(0)
void mlog_configure(const std::string &filename_base, bool console, const std::size_t max_log_file_size=MAX_LOG_FILE_SIZE, const std::size_t max_log_files=MAX_LOG_FILES)
std::string mlog_get_default_log_path(const char *default_filename)
std::string mlog_get_categories()
void mlog_set_log(const char *log)
void mlog_set_log_level(int level)
void mlog_set_categories(const char *categories)
#define MAX_LOG_FILE_SIZE
bool get_set_enable_assert(bool set=false, bool v=false)
void set_console_color(int color, bool bright)
void reset_console_color()