X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fmain.cpp;h=6c4b5a42e0d2c7974b7e578e7f98f5baab9af4ad;hp=199f175c752a8b4c4ad621b684ca98892db8fdfb;hb=ee8b9f55860e340c1600188fddcfd557c7489f66;hpb=89db85625af1f95cd62e4f5ae9aedf0ce20e9d59 diff --git a/src/common/main.cpp b/src/common/main.cpp index 199f175c..6c4b5a42 100644 --- a/src/common/main.cpp +++ b/src/common/main.cpp @@ -71,6 +71,7 @@ Q_IMPORT_PLUGIN(qgif) #endif #include "quassel.h" +#include "types.h" int main(int argc, char **argv) { @@ -78,6 +79,9 @@ int main(int argc, char **argv) umask(S_IRWXG | S_IRWXO); #endif + // Instantiate early, so log messages are handled + Quassel::instance(); + #if QT_VERSION < 0x050000 // All our source files are in UTF-8, and Qt5 even requires that QTextCodec::setCodecForCStrings(QTextCodec::codecForName("UTF-8")); @@ -192,7 +196,7 @@ int main(int argc, char **argv) cliParser->addOption("oidentd-conffile", 0, "Set path to oidentd configuration file", "file"); cliParser->addSwitch("strict-ident", 0, "Use users' quasselcore username as ident reply. Ignores each user's configured ident setting."); cliParser->addSwitch("ident-daemon", 0, "Enable internal ident daemon"); - cliParser->addOption("ident-port", 0, "The port quasselcore will listen at for ident requests. Only meaningful with --ident-daemon", "10113"); + cliParser->addOption("ident-port", 0, "The port quasselcore will listen at for ident requests. Only meaningful with --ident-daemon", "port", "10113"); #ifdef HAVE_SSL cliParser->addSwitch("require-ssl", 0, "Require SSL for remote (non-loopback) client connections"); cliParser->addOption("ssl-cert", 0, "Specify the path to the SSL Certificate", "path", "configdir/quasselCert.pem"); @@ -238,8 +242,15 @@ int main(int argc, char **argv) AboutData::setQuasselPersons(&aboutData); KAboutData::setApplicationData(aboutData.kAboutData()); #endif - if (!app.init()) - return EXIT_FAILURE; + try { + app.init(); + } + catch (ExitException e) { + if (!e.errorString.isEmpty()) { + qCritical() << e.errorString; + } + return e.exitCode; + } return app.exec(); }