X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtuiapplication.h;h=508bea5213d9011eca71d75b050ffcf05bd97df1;hp=567d4827840c8f8e94ef9178a8afc42408f7a796;hb=f88bfa81380ceb2c4afce5b15f753570a1ef063d;hpb=c52a94cb937654bf06d5074bf0736a52ec94a52d diff --git a/src/qtui/qtuiapplication.h b/src/qtui/qtuiapplication.h index 567d4827..508bea52 100644 --- a/src/qtui/qtuiapplication.h +++ b/src/qtui/qtuiapplication.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2015 by the Quassel Project * + * Copyright (C) 2005-2018 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -18,8 +18,7 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ -#ifndef QTUIAPPLICATION_H_ -#define QTUIAPPLICATION_H_ +#pragma once #ifdef HAVE_KDE4 # include @@ -31,14 +30,15 @@ #include "quassel.h" #include "uisettings.h" +#include "qtuisettings.h" class QtUi; #ifdef HAVE_KDE4 -class QtUiApplication : public KApplication, public Quassel +class QtUiApplication : public KApplication { #else -class QtUiApplication : public QApplication, public Quassel +class QtUiApplication : public QApplication { #endif @@ -47,20 +47,45 @@ class QtUiApplication : public QApplication, public Quassel public: QtUiApplication(int &, char **); ~QtUiApplication(); - virtual bool init(); + virtual void init(); void resumeSessionIfPossible(); - virtual void commitData(QSessionManager &manager); - virtual void saveState(QSessionManager &manager); - inline bool isAboutToQuit() const { return _aboutToQuit; } -protected: - virtual void quit(); +#if (QT_VERSION < QT_VERSION_CHECK(5, 0, 0)) + void commitData(QSessionManager &manager) override; + void saveState(QSessionManager &manager) override; +#else + void commitData(QSessionManager &manager); + void saveState(QSessionManager &manager); +#endif private: - bool _aboutToQuit; -}; + /** + * Migrate settings if neccessary and possible + * + * If unsuccessful (major version changed, minor version upgrade failed), returning false, the + * settings are in an unknown state and the client should quit. + * + * @return True if settings successfully migrated, otherwise false + */ + bool migrateSettings(); + /** + * Migrate from one minor settings version to the next + * + * Settings can only be migrated one version at a time. Start from the current version, calling + * this function for each intermediate version up until the latest version. + * + * @param[in] settings Current settings instance + * @param[in] newVersion Next target version for migration, at most 1 from the current version + * @return True if minor revision of settings successfully migrated, otherwise false + */ + bool applySettingsMigration(QtUiSettings settings, const uint newVersion); -#endif +private slots: + void initUi(); + +private: + bool _aboutToQuit{false}; +};