catch exceptions in hyperiond (#92)

This commit is contained in:
redPanther 2016-07-10 12:18:40 +02:00 committed by brindosch
parent 0feb1d7b58
commit 12cae1e634

View File

@ -2,6 +2,7 @@
#include <csignal> #include <csignal>
#include <unistd.h> #include <unistd.h>
#include <sys/prctl.h> #include <sys/prctl.h>
#include <exception>
#include <QCoreApplication> #include <QCoreApplication>
#include <QLocale> #include <QLocale>
@ -144,16 +145,24 @@ int main(int argc, char** argv)
hyperiond = new HyperionDaemon(configFiles[argvId], &app); hyperiond = new HyperionDaemon(configFiles[argvId], &app);
hyperiond->run(); hyperiond->run();
} }
catch (...) catch (std::exception& e)
{ {
Error(log, "Hyperion Daemon aborted"); Error(log, "Hyperion Daemon aborted:\n %s", e.what());
} }
WebConfig* webConfig = new WebConfig(&app); int rc = 1;
WebConfig* webConfig = nullptr;
// run the application try
int rc = app.exec(); {
Info(log, "INFO: Application closed with code %d", rc); webConfig = new WebConfig(&app);
// run the application
rc = app.exec();
Info(log, "INFO: Application closed with code %d", rc);
}
catch (std::exception& e)
{
Error(log, "Hyperion aborted:\n %s", e.what());
}
// delete components // delete components
delete webConfig; delete webConfig;