/**************************************************************************** ** ** Copyright (C) 2017 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of Qt Creator. ** ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see https://www.qt.io/terms-conditions. For further ** information use the contact form at https://www.qt.io/contact-us. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3 as published by the Free Software ** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT ** included in the packaging of this file. Please review the following ** information to ensure the GNU General Public License requirements will ** be met: https://www.gnu.org/licenses/gpl-3.0.html. ** ****************************************************************************/ #pragma once #include "utils_global.h" #include "fileutils.h" #include "optional.h" #include "persistentsettings.h" #include #include #include #include namespace Utils { // -------------------------------------------------------------------- // BasicSettingsAccessor: // -------------------------------------------------------------------- // Read/write files incl. error handling suitable for the UI: class QTCREATOR_UTILS_EXPORT BasicSettingsAccessor { public: BasicSettingsAccessor(const QString &docType, const QString &displayName, const QString &applicationDisplayName); virtual ~BasicSettingsAccessor() = default; enum ProceedInfo { Continue, DiscardAndContinue }; typedef QHash ButtonMap; class Issue { public: Issue(const QString &title, const QString &message) : title{title}, message{message} { } QMessageBox::StandardButtons allButtons() const; QString title; QString message; QMessageBox::StandardButton defaultButton = QMessageBox::NoButton; QMessageBox::StandardButton escapeButton = QMessageBox::Ok; QHash buttons = {{QMessageBox::Ok, ProceedInfo::Continue}}; }; class RestoreData { public: RestoreData() = default; RestoreData(const Utils::FileName &path, const QVariantMap &data) : path{path}, data{data} { } RestoreData(const QString &title, const QString &message) : RestoreData(Issue(title, message)) { } RestoreData(const Issue &issue) : issue{issue} { } Utils::FileName path; QVariantMap data; Utils::optional issue; }; QVariantMap restoreSettings(QWidget *parent) const; bool saveSettings(const QVariantMap &data, QWidget *parent) const; const QString docType; const QString displayName; const QString applicationDisplayName; void setBaseFilePath(const Utils::FileName &baseFilePath) { m_baseFilePath = baseFilePath; } Utils::FileName baseFilePath() const { return m_baseFilePath; } virtual RestoreData readData(const Utils::FileName &path, QWidget *parent) const; virtual Utils::optional writeData(const Utils::FileName &path, const QVariantMap &data) const; protected: // Report errors: ProceedInfo reportIssues(const Issue &issue, const FileName &path, QWidget *parent) const; virtual QVariantMap preprocessReadSettings(const QVariantMap &data) const; virtual QVariantMap prepareToWriteSettings(const QVariantMap &data) const; RestoreData readFile(const Utils::FileName &path) const; Utils::optional writeFile(const Utils::FileName &path, const QVariantMap &data) const; private: Utils::FileName m_baseFilePath; mutable std::unique_ptr m_writer; }; // -------------------------------------------------------------------- // VersionUpgrader: // -------------------------------------------------------------------- // Handles updating a QVariantMap from version() to version() + 1 class QTCREATOR_UTILS_EXPORT VersionUpgrader { public: VersionUpgrader(const int version, const QString &extension); virtual ~VersionUpgrader() = default; int version() const; QString backupExtension() const; virtual QVariantMap upgrade(const QVariantMap &data) = 0; protected: typedef QPair Change; QVariantMap renameKeys(const QList &changes, QVariantMap map) const; private: const int m_version; const QString m_extension; }; class SettingsAccessorPrivate; class QTCREATOR_UTILS_EXPORT SettingsAccessor : public BasicSettingsAccessor { public: explicit SettingsAccessor(const Utils::FileName &baseFile, const QString &docType, const QString &displayName, const QString &appDisplayName); ~SettingsAccessor() override; static QVariantMap setVersionInMap(const QVariantMap &data, int version); static int versionFromMap(const QVariantMap &data); static int originalVersionFromMap(const QVariantMap &data); static QVariantMap setOriginalVersionInMap(const QVariantMap &data, int version); int currentVersion() const; int firstSupportedVersion() const; bool addVersionUpgrader(std::unique_ptr upgrader); Utils::FileName projectUserFile() const; Utils::FileName externalUserFile() const; Utils::FileName sharedFile() const; protected: RestoreData readData(const Utils::FileName &path, QWidget *parent) const final; Utils::optional writeData(const Utils::FileName &path, const QVariantMap &data) const final; void setSettingsId(const QByteArray &id); QVariantMap upgradeSettings(const QVariantMap &data) const; QVariantMap upgradeSettings(const QVariantMap &data, const int targetVersion) const; QVariantMap prepareToWriteSettings(const QVariantMap &data) const override; virtual bool isBetterMatch(const QVariantMap &origData, const QVariantMap &newData) const; virtual bool isValidVersionAndId(const int version, const QByteArray &id) const; virtual Utils::FileName backupName(const QVariantMap &data) const; virtual void storeSharedSettings(const QVariantMap &data) const; virtual QVariant retrieveSharedSettings() const; QVariantMap mergeSettings(const QVariantMap &userMap, const QVariantMap &sharedMap) const; Utils::optional findIssues(const QVariantMap &data, const Utils::FileName &path) const; private: Utils::FileNameList settingsFiles() const; QByteArray settingsId() const; void backupUserFile() const; RestoreData readUserSettings(QWidget *parent) const; RestoreData readSharedSettings(QWidget *parent) const; static QByteArray settingsIdFromMap(const QVariantMap &data); static QString differentEnvironmentMsg(const QString &projectName); SettingsAccessorPrivate *d; friend class SettingsAccessorPrivate; }; } // namespace Utils