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 // 100 MB - 7600 bytes 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) 138 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);
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 257 #endif //_MISC_LOG_EX_H_ void mlog_set_log(const char *log)
Definition: mlog.cpp:289
::std::string string
Definition: gtest-port.h:1097
bool mwarning(const char *category, const char *format,...) ATTRIBUTE_PRINTF
std::string mlog_get_categories()
Definition: mlog.cpp:277
bool merror(const char *category, const char *format,...) ATTRIBUTE_PRINTF
e
Definition: pymoduletest.py:79
#define ATTRIBUTE_PRINTF
Definition: misc_log_ex.h:242
void reset_console_color()
Definition: mlog.cpp:471
static void log()
Definition: logging.cpp:85
void mlog_set_log_level(int level)
Definition: mlog.cpp:283
void set_console_color(int color, bool bright)
Definition: mlog.cpp:349
bool mtrace(const char *category, const char *format,...) ATTRIBUTE_PRINTF
TODO: (mj-xmr) This will be reduced in an another PR.
Definition: byte_slice.h:39
bool is_stdout_a_tty()
Definition: mlog.cpp:324
bool minfo(const char *category, const char *format,...) ATTRIBUTE_PRINTF
std::string mlog_get_default_log_path(const char *default_filename)
Definition: mlog.cpp:72
void mlog_set_categories(const char *categories)
Definition: mlog.cpp:239
bool mdebug(const char *category, const char *format,...) ATTRIBUTE_PRINTF
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
#define const
Definition: ipfrdr.c:80