Commit ba09e22c authored by Max Kellermann's avatar Max Kellermann

util/Exception: add GetFullMessage(std::exception)

parent 6515b972
...@@ -30,20 +30,27 @@ ...@@ -30,20 +30,27 @@
#include "Exception.hxx" #include "Exception.hxx"
std::string std::string
GetFullMessage(const std::exception &e,
const char *fallback, const char *separator) noexcept
{
try {
std::rethrow_if_nested(e);
return e.what();
} catch (...) {
return std::string(e.what()) + separator +
GetFullMessage(std::current_exception(),
fallback, separator);
}
}
std::string
GetFullMessage(std::exception_ptr ep, GetFullMessage(std::exception_ptr ep,
const char *fallback, const char *separator) noexcept const char *fallback, const char *separator) noexcept
{ {
try { try {
std::rethrow_exception(ep); std::rethrow_exception(ep);
} catch (const std::exception &e) { } catch (const std::exception &e) {
try { return GetFullMessage(e, fallback, separator);
std::rethrow_if_nested(e);
return e.what();
} catch (...) {
return std::string(e.what()) + separator +
GetFullMessage(std::current_exception(),
fallback, separator);
}
} catch (const std::nested_exception &ne) { } catch (const std::nested_exception &ne) {
return GetFullMessage(ne.nested_ptr(), fallback, separator); return GetFullMessage(ne.nested_ptr(), fallback, separator);
} }
......
...@@ -34,6 +34,15 @@ ...@@ -34,6 +34,15 @@
#include <string> #include <string>
/** /**
* Obtain the full concatenated message of an exception and its nested
* chain.
*/
std::string
GetFullMessage(const std::exception &e,
const char *fallback="Unknown exception",
const char *separator="; ") noexcept;
/**
* Extract the full message of a C++ exception, considering its nested * Extract the full message of a C++ exception, considering its nested
* exceptions (if any). * exceptions (if any).
*/ */
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment