X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;ds=sidebyside;f=src%2Fqtui%2Fqtuiapplication.cpp;h=cb4f91c81b0e1a8aabd8f2e5e17ffa5fd94c35e8;hb=fcacaaf16551524c7ebb6114254d005274cc3d63;hp=fc04f59be7839161869265b7d0f5aa80673cacdd;hpb=c015fbf8afaf64fbb5a8e2122e2a1ecf0325b1a1;p=quassel.git diff --git a/src/qtui/qtuiapplication.cpp b/src/qtui/qtuiapplication.cpp index fc04f59b..cb4f91c8 100644 --- a/src/qtui/qtuiapplication.cpp +++ b/src/qtui/qtuiapplication.cpp @@ -24,12 +24,7 @@ #include #include -#ifdef HAVE_KDE4 -# include -#endif - #include "chatviewsettings.h" -#include "cliparser.h" #include "logmessage.h" #include "mainwin.h" #include "qtui.h" @@ -37,59 +32,12 @@ #include "types.h" QtUiApplication::QtUiApplication(int &argc, char **argv) -#ifdef HAVE_KDE4 - : KApplication() // KApplication is deprecated in KF5 -#else : QApplication(argc, argv) -#endif { -#ifdef HAVE_KDE4 - Q_UNUSED(argc); Q_UNUSED(argv); - - // Setup KDE's data dirs - // Because we can't use KDE stuff in (the class) Quassel directly, we need to do this here... - QStringList dataDirs = KGlobal::dirs()->findDirs("data", ""); - - // Just in case, also check our install prefix - dataDirs << QCoreApplication::applicationDirPath() + "/../share/apps/"; - - // Normalize and append our application name - for (int i = 0; i < dataDirs.count(); i++) - dataDirs[i] = QDir::cleanPath(dataDirs.at(i)) + "/quassel/"; - - // Add resource path and just in case. - // Workdir should have precedence - dataDirs.prepend(QCoreApplication::applicationDirPath() + "/data/"); - dataDirs.append(":/data/"); - - // Append trailing '/' and check for existence - auto iter = dataDirs.begin(); - while (iter != dataDirs.end()) { - if (!iter->endsWith(QDir::separator()) && !iter->endsWith('/')) - iter->append(QDir::separator()); - if (!QFile::exists(*iter)) - iter = dataDirs.erase(iter); - else - ++iter; - } - - dataDirs.removeDuplicates(); - Quassel::setDataDirPaths(dataDirs); - -#else /* HAVE_KDE4 */ - - Quassel::setDataDirPaths(Quassel::findDataDirPaths()); - -#endif /* HAVE_KDE4 */ - - Quassel::setRunMode(Quassel::ClientOnly); - -#if QT_VERSION >= 0x050000 connect(this, &QGuiApplication::commitDataRequest, this, &QtUiApplication::commitData, Qt::DirectConnection); connect(this, &QGuiApplication::saveStateRequest, this, &QtUiApplication::saveState, Qt::DirectConnection); -#endif -#if (QT_VERSION >= QT_VERSION_CHECK(5, 6, 0)) +#if QT_VERSION >= 0x050600 QGuiApplication::setFallbackSessionManagementEnabled(false); #endif } @@ -97,20 +45,16 @@ QtUiApplication::QtUiApplication(int &argc, char **argv) void QtUiApplication::init() { - if (!Quassel::init()) { - throw ExitException{EXIT_FAILURE, tr("Could not initialize Quassel!")}; - } - // Settings upgrade/downgrade handling if (!migrateSettings()) { throw ExitException{EXIT_FAILURE, tr("Could not load or upgrade client settings!")}; } - _client.reset(new Client(std::unique_ptr(new QtUi()))); // TODO C++14: std::make_unique + _client = std::make_unique(std::make_unique()); // Init UI only after the event loop has started // TODO Qt5: Make this a lambda - QTimer::singleShot(0, this, SLOT(initUi())); + QTimer::singleShot(0, this, &QtUiApplication::initUi); }