X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fmain.cpp;h=0ee13ecd4305c2bf53c313b7fa4f6ef35d7e7fda;hp=6a36e5473251b7c3268b40785537ba144d2cf3c4;hb=534f170271bf6e3749a1c10ca6518eb7746e71f0;hpb=7d4dbdf00ab92e8c322656bd2d4d7034ef547001 diff --git a/src/common/main.cpp b/src/common/main.cpp index 6a36e547..0ee13ecd 100644 --- a/src/common/main.cpp +++ b/src/common/main.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2018 by the Quassel Project * + * Copyright (C) 2005-2019 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -26,6 +26,7 @@ # include #endif /* HAVE_UMASK */ +#include #include #ifdef BUILD_CORE @@ -70,6 +71,7 @@ Q_IMPORT_PLUGIN(qgif) #endif #include "quassel.h" +#include "types.h" int main(int argc, char **argv) { @@ -77,6 +79,9 @@ int main(int argc, char **argv) umask(S_IRWXG | S_IRWXO); #endif + // Instantiate early, so log messages are handled + Quassel quassel; + #if QT_VERSION < 0x050000 // All our source files are in UTF-8, and Qt5 even requires that QTextCodec::setCodecForCStrings(QTextCodec::codecForName("UTF-8")); @@ -93,13 +98,21 @@ int main(int argc, char **argv) #if QT_VERSION < 0x050000 && defined Q_OS_MAC && !defined BUILD_CORE QApplication::setGraphicsSystem("raster"); #endif - +//Setup the High-DPI settings +# if QT_VERSION >= 0x050600 && defined(Q_OS_WIN) + QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling); //Added in Qt 5.6 +#endif +# if QT_VERSION >= 0x050400 + //Added in the early Qt5 versions (5.0?)- use 5.4 as the cutoff since lots of high-DPI work was added then + QCoreApplication::setAttribute(Qt::AA_UseHighDpiPixmaps); +# endif // We need to explicitly initialize the required resources when linking statically #ifndef BUILD_QTUI Q_INIT_RESOURCE(sql); #endif #ifndef BUILD_CORE Q_INIT_RESOURCE(pics); + Q_INIT_RESOURCE(hicolor_icons); #endif #ifdef EMBED_DATA @@ -182,11 +195,20 @@ int main(int argc, char **argv) cliParser->addSwitch("oidentd", 0, "Enable oidentd integration. In most cases you should also enable --strict-ident"); 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", "port", "10113"); + cliParser->addOption("ident-listen", 0, "The address(es) quasselcore will listen on for ident requests. Same format as --listen.", "
[,...]", "::1,127.0.0.1"); #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"); cliParser->addOption("ssl-key", 0, "Specify the path to the SSL key", "path", "ssl-cert-path"); #endif + cliParser->addSwitch("debug-irc", 0, + "Enable logging of all raw IRC messages to debug log, including " + "passwords! In most cases you should also set --loglevel Debug"); + cliParser->addOption("debug-irc-id", 0, + "Limit raw IRC logging to this network ID. Implies --debug-irc", + "database network ID", "-1"); cliParser->addSwitch("enable-experimental-dcc", 0, "Enable highly experimental and unfinished support for CTCP DCC (DANGEROUS)"); #endif @@ -201,20 +223,8 @@ int main(int argc, char **argv) #if defined BUILD_CORE CoreApplication app(argc, argv); #elif defined BUILD_QTUI -# if QT_VERSION >= 0x050600 && defined(Q_OS_WIN) - QtUiApplication::setAttribute(Qt::AA_EnableHighDpiScaling); -#endif -# if QT_VERSION >= 0x050700 - QtUiApplication::setAttribute(Qt::AA_UseHighDpiPixmaps); -# endif QtUiApplication app(argc, argv); #elif defined BUILD_MONO -# if QT_VERSION >= 0x050600 && defined(Q_OS_WIN) - MonolithicApplication::setAttribute(Qt::AA_EnableHighDpiScaling); -#endif -# if QT_VERSION >= 0x050700 - MonolithicApplication::setAttribute(Qt::AA_UseHighDpiPixmaps); -# endif MonolithicApplication app(argc, argv); #endif @@ -239,9 +249,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() << qPrintable(e.errorString); + } + return e.exitCode; + } return app.exec(); }