28#ifndef _MISC_LOG_EX_H_
29#define _MISC_LOG_EX_H_
38#undef MONERO_DEFAULT_LOG_CATEGORY
39#define MONERO_DEFAULT_LOG_CATEGORY "default"
41#define MAX_LOG_FILE_SIZE 104850000
42#define MAX_LOG_FILES 50
44#define LOG_TO_STRING(x) \
45 std::stringstream ss; \
47 const std::string str = ss.str();
49#define MCLOG_TYPE(level, cat, color, type, x) do { \
50 if (el::Loggers::allowed(level, cat)) { \
52 el::base::Writer(level, color, __FILE__, __LINE__, ELPP_FUNC, type).construct(cat) << str; \
56#define MCLOG(level, cat, color, x) MCLOG_TYPE(level, cat, color, el::base::DispatchAction::NormalLog, x)
57#define MCLOG_FILE(level, cat, x) MCLOG_TYPE(level, cat, el::Color::Default, el::base::DispatchAction::FileOnlyLog, x)
59#define MCFATAL(cat,x) MCLOG(el::Level::Fatal,cat, el::Color::Default, x)
60#define MCERROR(cat,x) MCLOG(el::Level::Error,cat, el::Color::Default, x)
61#define MCWARNING(cat,x) MCLOG(el::Level::Warning,cat, el::Color::Default, x)
62#define MCINFO(cat,x) MCLOG(el::Level::Info,cat, el::Color::Default, x)
63#define MCDEBUG(cat,x) MCLOG(el::Level::Debug,cat, el::Color::Default, x)
64#define MCTRACE(cat,x) MCLOG(el::Level::Trace,cat, el::Color::Default, x)
66#define MCLOG_COLOR(level,cat,color,x) MCLOG(level,cat,color,x)
67#define MCLOG_RED(level,cat,x) MCLOG_COLOR(level,cat,el::Color::Red,x)
68#define MCLOG_GREEN(level,cat,x) MCLOG_COLOR(level,cat,el::Color::Green,x)
69#define MCLOG_YELLOW(level,cat,x) MCLOG_COLOR(level,cat,el::Color::Yellow,x)
70#define MCLOG_BLUE(level,cat,x) MCLOG_COLOR(level,cat,el::Color::Blue,x)
71#define MCLOG_MAGENTA(level,cat,x) MCLOG_COLOR(level,cat,el::Color::Magenta,x)
72#define MCLOG_CYAN(level,cat,x) MCLOG_COLOR(level,cat,el::Color::Cyan,x)
74#define MLOG_RED(level,x) MCLOG_RED(level,MONERO_DEFAULT_LOG_CATEGORY,x)
75#define MLOG_GREEN(level,x) MCLOG_GREEN(level,MONERO_DEFAULT_LOG_CATEGORY,x)
76#define MLOG_YELLOW(level,x) MCLOG_YELLOW(level,MONERO_DEFAULT_LOG_CATEGORY,x)
77#define MLOG_BLUE(level,x) MCLOG_BLUE(level,MONERO_DEFAULT_LOG_CATEGORY,x)
78#define MLOG_MAGENTA(level,x) MCLOG_MAGENTA(level,MONERO_DEFAULT_LOG_CATEGORY,x)
79#define MLOG_CYAN(level,x) MCLOG_CYAN(level,MONERO_DEFAULT_LOG_CATEGORY,x)
81#define MFATAL(x) MCFATAL(MONERO_DEFAULT_LOG_CATEGORY,x)
82#define MERROR(x) MCERROR(MONERO_DEFAULT_LOG_CATEGORY,x)
83#define MWARNING(x) MCWARNING(MONERO_DEFAULT_LOG_CATEGORY,x)
84#define MINFO(x) MCINFO(MONERO_DEFAULT_LOG_CATEGORY,x)
85#define MDEBUG(x) MCDEBUG(MONERO_DEFAULT_LOG_CATEGORY,x)
86#define MTRACE(x) MCTRACE(MONERO_DEFAULT_LOG_CATEGORY,x)
87#define MLOG(level,x) MCLOG(level,MONERO_DEFAULT_LOG_CATEGORY,el::Color::Default,x)
89#define MGINFO(x) MCINFO("global",x)
90#define MGINFO_RED(x) MCLOG_RED(el::Level::Info, "global",x)
91#define MGINFO_GREEN(x) MCLOG_GREEN(el::Level::Info, "global",x)
92#define MGINFO_YELLOW(x) MCLOG_YELLOW(el::Level::Info, "global",x)
93#define MGINFO_BLUE(x) MCLOG_BLUE(el::Level::Info, "global",x)
94#define MGINFO_MAGENTA(x) MCLOG_MAGENTA(el::Level::Info, "global",x)
95#define MGINFO_CYAN(x) MCLOG_CYAN(el::Level::Info, "global",x)
97#define IFLOG(level, cat, color, type, init, x) \
99 if (el::Loggers::allowed(level, cat)) { \
102 el::base::Writer(level, color, __FILE__, __LINE__, ELPP_FUNC, type).construct(cat) << str; \
105#define MIDEBUG(init, x) IFLOG(el::Level::Debug, MONERO_DEFAULT_LOG_CATEGORY, el::Color::Default, el::base::DispatchAction::NormalLog, init, x)
108#define LOG_ERROR(x) MERROR(x)
109#define LOG_PRINT_L0(x) MWARNING(x)
110#define LOG_PRINT_L1(x) MINFO(x)
111#define LOG_PRINT_L2(x) MDEBUG(x)
112#define LOG_PRINT_L3(x) MTRACE(x)
113#define LOG_PRINT_L4(x) MTRACE(x)
115#define _dbg3(x) MTRACE(x)
116#define _dbg2(x) MDEBUG(x)
117#define _dbg1(x) MDEBUG(x)
118#define _info(x) MINFO(x)
119#define _note(x) MDEBUG(x)
120#define _fact(x) MDEBUG(x)
121#define _mark(x) MDEBUG(x)
122#define _warn(x) MWARNING(x)
123#define _erro(x) MERROR(x)
125#define MLOG_SET_THREAD_NAME(x) el::Helpers::setThreadName(x)
129#if (defined _MSC_VER)
130#define LOCAL_ASSERT(expr) {if(epee::debug::get_set_enable_assert()){_ASSERTE(expr);}}
132#define LOCAL_ASSERT(expr)
138void 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);
148 inline bool get_set_enable_assert(
bool set =
false,
bool v =
false)
150 static bool e =
true;
159#define ENDL std::endl
161#define TRY_ENTRY() try {
162#define CATCH_ENTRY(location, return_val) } \
163 catch(const std::exception& ex) \
166 LOG_ERROR("Exception at [" << location << "], what=" << ex.what()); \
171 LOG_ERROR("Exception at [" << location << "], generic exception \"...\"");\
175#define CATCH_ENTRY_L0(lacation, return_val) CATCH_ENTRY(lacation, return_val)
176#define CATCH_ENTRY_L1(lacation, return_val) CATCH_ENTRY(lacation, return_val)
177#define CATCH_ENTRY_L2(lacation, return_val) CATCH_ENTRY(lacation, return_val)
178#define CATCH_ENTRY_L3(lacation, return_val) CATCH_ENTRY(lacation, return_val)
179#define CATCH_ENTRY_L4(lacation, return_val) CATCH_ENTRY(lacation, return_val)
182#define ASSERT_MES_AND_THROW(message) {LOG_ERROR(message); std::stringstream ss; ss << message; throw std::runtime_error(ss.str());}
183#define CHECK_AND_ASSERT_THROW_MES(expr, message) do {if(!(expr)) ASSERT_MES_AND_THROW(message);} while(0)
186#ifndef CHECK_AND_ASSERT
187#define CHECK_AND_ASSERT(expr, fail_ret_val) do{if(!(expr)){LOCAL_ASSERT(expr); return fail_ret_val;};}while(0)
190#ifndef CHECK_AND_ASSERT_MES
191#define CHECK_AND_ASSERT_MES(expr, fail_ret_val, message) do{if(!(expr)) {LOG_ERROR(message); return fail_ret_val;};}while(0)
194#ifndef CHECK_AND_NO_ASSERT_MES_L
195#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)
198#ifndef CHECK_AND_NO_ASSERT_MES
199#define CHECK_AND_NO_ASSERT_MES(expr, fail_ret_val, message) CHECK_AND_NO_ASSERT_MES_L(expr, fail_ret_val, 0, message)
202#ifndef CHECK_AND_NO_ASSERT_MES_L1
203#define CHECK_AND_NO_ASSERT_MES_L1(expr, fail_ret_val, message) CHECK_AND_NO_ASSERT_MES_L(expr, fail_ret_val, 1, message)
207#ifndef CHECK_AND_ASSERT_MES_NO_RET
208#define CHECK_AND_ASSERT_MES_NO_RET(expr, message) do{if(!(expr)) {LOG_ERROR(message); return;};}while(0)
212#ifndef CHECK_AND_ASSERT_MES2
213#define CHECK_AND_ASSERT_MES2(expr, message) do{if(!(expr)) {LOG_ERROR(message); };}while(0)
218 console_color_default,
224 console_color_magenta,
240#define ATTRIBUTE_PRINTF __attribute__((format(printf, 2, 3)))
242#define ATTRIBUTE_PRINTF
#define const
Definition ipfrdr.c:80
static void log()
Definition logging.cpp:85
bool merror(const char *category, const char *format,...) ATTRIBUTE_PRINTF
bool mdebug(const char *category, const char *format,...) ATTRIBUTE_PRINTF
bool minfo(const char *category, const char *format,...) ATTRIBUTE_PRINTF
bool mwarning(const char *category, const char *format,...) ATTRIBUTE_PRINTF
bool mtrace(const char *category, const char *format,...) ATTRIBUTE_PRINTF
#define ATTRIBUTE_PRINTF
Definition misc_log_ex.h:242
std::string mlog_get_default_log_path(const char *default_filename)
Definition mlog.cpp:72
std::string mlog_get_categories()
Definition mlog.cpp:277
void mlog_configure(const std::string &filename_base, bool console, const std::size_t max_log_file_size, const std::size_t max_log_files)
Definition mlog.cpp:148
void mlog_set_log(const char *log)
Definition mlog.cpp:289
void mlog_set_log_level(int level)
Definition mlog.cpp:283
void mlog_set_categories(const char *categories)
Definition mlog.cpp:239
TODO: (mj-xmr) This will be reduced in an another PR.
Definition byte_slice.h:40
void set_console_color(int color, bool bright)
Definition mlog.cpp:349
void reset_console_color()
Definition mlog.cpp:471
bool is_stdout_a_tty()
Definition mlog.cpp:324
e
Definition pymoduletest.py:79