X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Fqtuiapplication.cpp;h=abe103672f2f64c89d3caeec43d9a8727c551cf9;hb=176fd53453c51debbb963dee303e8853577aaac4;hp=90e2739d5dd35a2e62ea1ca2721801f03630c516;hpb=034708a59ca1ee3195263a90941a2b145c520fef;p=quassel.git diff --git a/src/qtui/qtuiapplication.cpp b/src/qtui/qtuiapplication.cpp index 90e2739d..abe10367 100644 --- a/src/qtui/qtuiapplication.cpp +++ b/src/qtui/qtuiapplication.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel IRC Team * + * Copyright (C) 2005-09 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -22,39 +22,41 @@ #include +#ifdef HAVE_KDE +# include +#endif + #include "client.h" #include "cliparser.h" #include "qtui.h" #include "sessionsettings.h" - -// void myMessageOutput(QtMsgType type, const char *msg) { -// Client::debugLog() << "Debug:" << msg << '\n'; -// return; -// // switch (type) { -// // case QtDebugMsg: -// // break; -// // case QtWarningMsg: -// // fprintf(stderr, "Warning: %s\n", msg); -// // break; -// // case QtCriticalMsg: -// // fprintf(stderr, "Critical: %s\n", msg); -// // break; -// // case QtFatalMsg: -// // fprintf(stderr, "Fatal: %s\n", msg); -// // abort(); -// // } -// } - QtUiApplication::QtUiApplication(int &argc, char **argv) - : QApplication(argc, argv), Quassel() +#ifdef HAVE_KDE + : KApplication(), +#else + : QApplication(argc, argv), +#endif + Quassel(), + _aboutToQuit(false) { - setRunMode(Quassel::ClientOnly); +#ifdef HAVE_KDE + Q_UNUSED(argc); Q_UNUSED(argv); + + // We need to setup KDE's data dirs + QStringList dataDirs = KGlobal::dirs()->findDirs("data", ""); + for(int i = 0; i < dataDirs.count(); i++) + dataDirs[i].append("quassel/"); + dataDirs.append(":/data/"); + setDataDirPaths(dataDirs); + +#else /* HAVE_KDE */ - // put client-only arguments here - CliParser *parser = Quassel::cliParser(); - parser->addSwitch("debugbufferswitches",0,"Enables debugging for bufferswitches"); - parser->addSwitch("debugmodel",0,"Enables debugging for models"); + setDataDirPaths(findDataDirPaths()); + +#endif /* HAVE_KDE */ + + setRunMode(Quassel::ClientOnly); qInstallMsgHandler(Client::logMessage); } @@ -77,6 +79,10 @@ QtUiApplication::~QtUiApplication() { Client::destroy(); } +void QtUiApplication::commitData(QSessionManager &manager) { + _aboutToQuit = true; +} + void QtUiApplication::saveState(QSessionManager & manager) { //qDebug() << QString("saving session state to id %1").arg(manager.sessionId()); AccountId activeCore = Client::currentCoreAccount();