X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtuiapplication.cpp;h=c2157a057a0e36f79922a0bd53022ad32c8d9150;hp=de9844f291e5b3006b839e31bcad03a77bb92980;hb=46984aca05b2d5f8dddd0c8739e60a1753078123;hpb=5080325e7f8c5cf95bbcddf0e2e0cfd2233a5795 diff --git a/src/qtui/qtuiapplication.cpp b/src/qtui/qtuiapplication.cpp index de9844f2..c2157a05 100644 --- a/src/qtui/qtuiapplication.cpp +++ b/src/qtui/qtuiapplication.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-09 by the Quassel Project * + * Copyright (C) 2005-2010 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -28,9 +28,9 @@ #include "client.h" #include "cliparser.h" +#include "mainwin.h" #include "qtui.h" #include "qtuisettings.h" -#include "sessionsettings.h" QtUiApplication::QtUiApplication(int &argc, char **argv) #ifdef HAVE_KDE @@ -57,6 +57,9 @@ QtUiApplication::QtUiApplication(int &argc, char **argv) #endif /* HAVE_KDE */ +#if defined(HAVE_KDE) || defined(Q_OS_MAC) + disableCrashhandler(); +#endif /* HAVE_KDE || Q_OS_MAC */ setRunMode(Quassel::ClientOnly); qInstallMsgHandler(Client::logMessage); @@ -125,6 +128,10 @@ QtUiApplication::~QtUiApplication() { Client::destroy(); } +void QtUiApplication::quit() { + QtUi::mainWindow()->quit(); +} + void QtUiApplication::commitData(QSessionManager &manager) { Q_UNUSED(manager) _aboutToQuit = true; @@ -132,11 +139,10 @@ void QtUiApplication::commitData(QSessionManager &manager) { void QtUiApplication::saveState(QSessionManager & manager) { //qDebug() << QString("saving session state to id %1").arg(manager.sessionId()); - AccountId activeCore = Client::currentCoreAccount(); + AccountId activeCore = Client::currentCoreAccount().accountId(); // FIXME store this! SessionSettings s(manager.sessionId()); s.setSessionAge(0); - emit saveStateToSession(manager.sessionId()); - emit saveStateToSessionSettings(s); + QtUi::mainWindow()->saveStateToSettings(s); } void QtUiApplication::resumeSessionIfPossible() { @@ -146,8 +152,7 @@ void QtUiApplication::resumeSessionIfPossible() { SessionSettings s(sessionId()); s.sessionAging(); s.setSessionAge(0); - emit resumeFromSession(sessionId()); - emit resumeFromSessionSettings(s); + QtUi::mainWindow()->restoreStateFromSettings(s); s.cleanup(); } else { SessionSettings s(QString("1"));