2021-01-18 08:28:54 +01:00
|
|
|
/* Copyright 2013-2021 MultiMC Contributors
|
2013-02-25 13:24:46 -06:00
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
2013-11-04 02:53:05 +01:00
|
|
|
*
|
2013-02-25 13:24:46 -06:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2013-11-04 02:53:05 +01:00
|
|
|
#pragma once
|
2013-02-25 13:24:46 -06:00
|
|
|
|
|
|
|
#include <QObject>
|
2014-01-01 15:08:40 +01:00
|
|
|
#include <QStringList>
|
2023-08-14 18:16:53 +02:00
|
|
|
#include <QVariant>
|
2014-01-01 15:08:40 +01:00
|
|
|
#include <memory>
|
2013-02-25 13:24:46 -06:00
|
|
|
|
|
|
|
class SettingsObject;
|
|
|
|
|
|
|
|
/*!
|
2013-11-04 02:53:05 +01:00
|
|
|
*
|
2013-02-25 13:24:46 -06:00
|
|
|
*/
|
2023-08-14 18:16:53 +02:00
|
|
|
class Setting : public QObject {
|
2013-02-25 13:24:46 -06:00
|
|
|
Q_OBJECT
|
2023-08-14 18:16:53 +02:00
|
|
|
public:
|
2014-01-01 15:30:26 +01:00
|
|
|
/**
|
|
|
|
* Construct a Setting
|
2015-09-05 18:46:57 +02:00
|
|
|
*
|
2014-01-01 15:30:26 +01:00
|
|
|
* Synonyms are all the possible names used in the settings object, in order of preference.
|
2022-10-18 20:07:04 +05:30
|
|
|
* First synonym is the ID, which identifies the setting in Prism Launcher.
|
2015-09-05 18:46:57 +02:00
|
|
|
*
|
2014-01-01 15:30:26 +01:00
|
|
|
* defVal is the default value that will be returned when the settings object
|
|
|
|
* doesn't have any value for this setting.
|
2013-02-25 13:24:46 -06:00
|
|
|
*/
|
2014-01-01 15:08:40 +01:00
|
|
|
explicit Setting(QStringList synonyms, QVariant defVal = QVariant());
|
|
|
|
|
2013-02-25 13:24:46 -06:00
|
|
|
/*!
|
|
|
|
* \brief Gets this setting's ID.
|
|
|
|
* This is used to refer to the setting within the application.
|
2013-11-04 02:53:05 +01:00
|
|
|
* \warning Changing the ID while the setting is registered with a SettingsObject results in
|
|
|
|
* undefined behavior.
|
2013-02-25 13:24:46 -06:00
|
|
|
* \return The ID of the setting.
|
|
|
|
*/
|
2023-08-14 18:16:53 +02:00
|
|
|
virtual QString id() const { return m_synonyms.first(); }
|
2013-11-04 02:53:05 +01:00
|
|
|
|
2013-02-25 13:24:46 -06:00
|
|
|
/*!
|
|
|
|
* \brief Gets this setting's config file key.
|
|
|
|
* This is used to store the setting's value in the config file. It is usually
|
|
|
|
* the same as the setting's ID, but it can be different.
|
|
|
|
* \return The setting's config file key.
|
|
|
|
*/
|
2023-08-14 18:16:53 +02:00
|
|
|
virtual QStringList configKeys() const { return m_synonyms; }
|
2013-11-04 02:53:05 +01:00
|
|
|
|
2013-02-25 13:24:46 -06:00
|
|
|
/*!
|
|
|
|
* \brief Gets this setting's value as a QVariant.
|
|
|
|
* This is done by calling the SettingsObject's retrieveValue() function.
|
|
|
|
* If this Setting doesn't have a SettingsObject, this returns an invalid QVariant.
|
|
|
|
* \return QVariant containing this setting's value.
|
|
|
|
* \sa value()
|
|
|
|
*/
|
|
|
|
virtual QVariant get() const;
|
2013-11-04 02:53:05 +01:00
|
|
|
|
2013-02-25 13:24:46 -06:00
|
|
|
/*!
|
|
|
|
* \brief Gets this setting's default value.
|
|
|
|
* \return The default value of this setting.
|
|
|
|
*/
|
|
|
|
virtual QVariant defValue() const;
|
2013-11-04 02:53:05 +01:00
|
|
|
|
2023-08-14 18:16:53 +02:00
|
|
|
signals:
|
2013-02-25 13:24:46 -06:00
|
|
|
/*!
|
|
|
|
* \brief Signal emitted when this Setting object's value changes.
|
|
|
|
* \param setting A reference to the Setting that changed.
|
|
|
|
* \param value This Setting object's new value.
|
|
|
|
*/
|
2023-08-14 18:16:53 +02:00
|
|
|
void SettingChanged(const Setting& setting, QVariant value);
|
2013-11-04 02:53:05 +01:00
|
|
|
|
2013-07-16 00:30:32 +02:00
|
|
|
/*!
|
|
|
|
* \brief Signal emitted when this Setting object's value resets to default.
|
|
|
|
* \param setting A reference to the Setting that changed.
|
|
|
|
*/
|
2023-08-14 18:16:53 +02:00
|
|
|
void settingReset(const Setting& setting);
|
2013-11-04 02:53:05 +01:00
|
|
|
|
2023-08-14 18:16:53 +02:00
|
|
|
public slots:
|
2013-02-25 13:24:46 -06:00
|
|
|
/*!
|
|
|
|
* \brief Changes the setting's value.
|
2014-07-01 01:48:09 +02:00
|
|
|
* This is done by emitting the SettingChanged() signal which will then be
|
2013-02-25 13:24:46 -06:00
|
|
|
* handled by the SettingsObject object and cause the setting to change.
|
|
|
|
* \param value The new value.
|
|
|
|
*/
|
|
|
|
virtual void set(QVariant value);
|
2013-11-04 02:53:05 +01:00
|
|
|
|
2013-07-16 00:30:32 +02:00
|
|
|
/*!
|
|
|
|
* \brief Reset the setting to default
|
|
|
|
* This is done by emitting the settingReset() signal which will then be
|
|
|
|
* handled by the SettingsObject object and cause the setting to change.
|
|
|
|
*/
|
|
|
|
virtual void reset();
|
2013-11-04 02:53:05 +01:00
|
|
|
|
2023-08-14 18:16:53 +02:00
|
|
|
protected:
|
2014-01-01 15:08:40 +01:00
|
|
|
friend class SettingsObject;
|
2023-08-14 18:16:53 +02:00
|
|
|
SettingsObject* m_storage;
|
2014-01-01 15:08:40 +01:00
|
|
|
QStringList m_synonyms;
|
2013-02-25 13:24:46 -06:00
|
|
|
QVariant m_defVal;
|
|
|
|
};
|