command/Error: pass std::exception_ptr to PrintError()

Necessary to preserve type information.  The try/catch sequence didn't
work previously.
This commit is contained in:
Max Kellermann 2015-12-27 06:43:55 +01:00
parent 672e18cac9
commit 1c90400081
3 changed files with 15 additions and 8 deletions

View File

@ -418,6 +418,6 @@ try {
return ret;
} catch (const std::exception &e) {
Response r(client, num);
PrintError(r, e);
PrintError(r, std::current_exception());
return CommandResult::ERROR;
}

View File

@ -159,19 +159,26 @@ print_error(Response &r, const Error &error)
}
void
PrintError(Response &r, const std::exception &e)
PrintError(Response &r, std::exception_ptr ep)
{
try {
std::rethrow_exception(ep);
} catch (const std::exception &e) {
LogError(e);
} catch (...) {
}
try {
throw e;
std::rethrow_exception(ep);
} catch (const ProtocolError &pe) {
r.Error(pe.GetCode(), pe.what());
} catch (const PlaylistError &pe) {
r.Error(ToAck(pe.GetCode()), pe.what());
} catch (const std::system_error &) {
} catch (const std::system_error &e) {
r.Error(ACK_ERROR_SYSTEM, e.what());
} catch (...) {
} catch (const std::exception &e) {
r.Error(ACK_ERROR_UNKNOWN, e.what());
} catch (...) {
r.Error(ACK_ERROR_UNKNOWN, "Unknown error");
}
}

View File

@ -24,7 +24,7 @@
#include "PlaylistError.hxx"
namespace std {
class exception;
class exception_ptr;
}
class Response;
@ -40,6 +40,6 @@ CommandResult
print_error(Response &r, const Error &error);
void
PrintError(Response &r, const std::exception &e);
PrintError(Response &r, std::exception_ptr ep);
#endif