mirror of
https://github.com/kvazar-network/kevacoin.git
synced 2025-01-25 22:34:27 +00:00
util: Properly handle errors during log message formatting
Instead of having an exception propagate into the program when an error happens while formatting a log message, just print a message to the log. Addresses #9423.
This commit is contained in:
parent
e3e7db829e
commit
3b092bd9b6
22
src/util.h
22
src/util.h
@ -73,14 +73,24 @@ bool LogAcceptCategory(const char* category);
|
|||||||
/** Send a string to the log output */
|
/** Send a string to the log output */
|
||||||
int LogPrintStr(const std::string &str);
|
int LogPrintStr(const std::string &str);
|
||||||
|
|
||||||
#define LogPrint(category, ...) do { \
|
/** Get format string from VA_ARGS for error reporting */
|
||||||
if (LogAcceptCategory((category))) { \
|
template<typename... Args> std::string FormatStringFromLogArgs(const char *fmt, const Args&... args) { return fmt; }
|
||||||
LogPrintStr(tfm::format(__VA_ARGS__)); \
|
|
||||||
} \
|
|
||||||
} while(0)
|
|
||||||
|
|
||||||
#define LogPrintf(...) do { \
|
#define LogPrintf(...) do { \
|
||||||
LogPrintStr(tfm::format(__VA_ARGS__)); \
|
std::string _log_msg_; /* Unlikely name to avoid shadowing variables */ \
|
||||||
|
try { \
|
||||||
|
_log_msg_ = tfm::format(__VA_ARGS__); \
|
||||||
|
} catch (std::runtime_error &e) { \
|
||||||
|
/* Original format string will have newline so don't add one here */ \
|
||||||
|
_log_msg_ = "Error \"" + std::string(e.what()) + "\" while formatting log message: " + FormatStringFromLogArgs(__VA_ARGS__); \
|
||||||
|
} \
|
||||||
|
LogPrintStr(_log_msg_); \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
|
#define LogPrint(category, ...) do { \
|
||||||
|
if (LogAcceptCategory((category))) { \
|
||||||
|
LogPrintf(__VA_ARGS__); \
|
||||||
|
} \
|
||||||
} while(0)
|
} while(0)
|
||||||
|
|
||||||
template<typename... Args>
|
template<typename... Args>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user