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:
Wladimir J. van der Laan 2017-03-09 10:37:45 +00:00
parent e3e7db829e
commit 3b092bd9b6

View File

@ -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>