16#ifndef QGSSETTINGSENTRY_H
17#define QGSSETTINGSENTRY_H
29using namespace Qt::StringLiterals;
34static const inline QMetaEnum sSettingsTypeMetaEnum = QMetaEnum::fromType<Qgis::SettingsType>()
SIP_SKIP;
53 sipType = sipType_QgsSettingsEntryVariant;
55 sipType = sipType_QgsSettingsEntryString;
57 sipType = sipType_QgsSettingsEntryStringList;
59 sipType = sipType_QgsSettingsEntryVariantMap;
61 sipType = sipType_QgsSettingsEntryBool;
63 sipType = sipType_QgsSettingsEntryInteger;
65 sipType = sipType_QgsSettingsEntryDouble;
67 sipType = sipType_QgsSettingsEntryColor;
69 sipType = sipType_QgsSettingsEntryBase;
127 , mDefaultValue( defaultValue )
155 virtual QString typeId() const;
161 QString
name()
const {
return mName; }
168 QString
key(
const QString &dynamicKeyPart = QString() )
const;
175 QString
key(
const QStringList &dynamicKeyPartList )
const;
186 bool keyIsValid(
const QString &
key )
const;
193 QString definitionKey()
const;
198 bool hasDynamicKey()
const;
211 bool exists(
const QString &dynamicKeyPart = QString() )
const;
218 bool exists(
const QStringList &dynamicKeyPartList )
const;
232 void remove(
const QString &dynamicKeyPart = QString() )
const;
239 void remove(
const QStringList &dynamicKeyPartList )
const;
245 Q_DECL_DEPRECATED
int section()
const;
253 bool setVariantValue(
const QVariant &value,
const QString &dynamicKeyPart = QString() )
const;
261 bool setVariantValue(
const QVariant &value,
const QStringList &dynamicKeyPartList )
const;
264 QVariant valueAsVariant(
const QString &dynamicKeyPart = QString() )
const;
267 QVariant valueAsVariant(
const QStringList &dynamicKeyPartList )
const;
273 QVariant valueAsVariantWithDefaultOverride(
const QVariant &defaultValueOverride,
const QString &dynamicKeyPart = QString() )
const;
282 QVariant valueAsVariantWithDefaultOverride(
const QVariant &defaultValueOverride,
const QStringList &dynamicKeyPartList )
const;
288 Q_DECL_DEPRECATED QVariant valueAsVariant(
const QString &dynamicKeyPart,
bool useDefaultValueOverride,
const QVariant &defaultValueOverride )
const SIP_DEPRECATED;
294 Q_DECL_DEPRECATED QVariant valueAsVariant(
const QStringList &dynamicKeyPartList,
bool useDefaultValueOverride,
const QVariant &defaultValueOverride )
const SIP_DEPRECATED;
300 QVariant defaultValueAsVariant()
const;
311 QString description()
const;
318 QVariant formerValueAsVariant(
const QString &dynamicKeyPart )
const;
325 QVariant formerValueAsVariant(
const QStringList &dynamicKeyPartList )
const;
344 bool copyValueFromKey(
const QString &
key,
const QStringList &dynamicKeyPartList,
bool removeSettingAtKey =
false )
const;
352 void copyValueToKey(
const QString &
key,
const QStringList &dynamicKeyPartList = QStringList() )
const;
362 void copyValueToKeyIfChanged(
const QString &
key,
const QStringList &dynamicKeyPartList = QStringList() )
const;
385 QString formerValuekey(
const QStringList &dynamicKeyPartList )
const;
387 QString completeKeyPrivate(
const QString &
key,
const QStringList &dynamicKeyPartList )
const;
392 QVariant mDefaultValue;
393 QString mDescription;
395 mutable bool mHasChanged =
false;
SettingsType
Types of settings entries.
@ Custom
Custom implementation.
QFlags< SettingsOption > SettingsOptions
SettingsOrigin
The setting origin describes where a setting is stored.
QgsSettingsEntryBaseTemplate(const QString &name, QgsSettingsTreeNode *parent, const QVariant &defaultValue, const QString &description=QString(), Qgis::SettingsOptions options=Qgis::SettingsOptions())
Constructor for QgsSettingsEntryByReference.
virtual bool setValuePrivate(const T &value, const QStringList &dynamicKeyPartList) const
Sets the settings value with an optional list of dynamic parts.
Qgis::SettingsType settingsType() const override=0
Returns the settings entry type.
T valueWithDefaultOverride(const T &defaultValueOverride, const QString &dynamicKeyPart=QString()) const
Returns the settings value with a defaultValueOverride and with an optional dynamicKeyPart.
T defaultValue() const
Returns settings default value.
virtual T convertFromVariant(const QVariant &value) const =0
Converts the variant value to the value type of the setting.
T value(const QString &dynamicKeyPart=QString()) const
Returns settings value.
QgsSettingsEntryBaseTemplate(const QString &key, const QString §ion, const QVariant &defaultValue, const QString &description=QString(), Qgis::SettingsOptions options=Qgis::SettingsOptions())
Constructor for QgsSettingsEntryByReference.
virtual QVariant convertToVariant(const T &value) const
Converts the value to a variant.
bool checkValueVariant(const QVariant &value) const override
Returns true if the given value is valid towards the setting definition.
T value(const QStringList &dynamicKeyPartList) const
Returns settings value.
bool setValue(const T &value, const QString &dynamicKeyPart=QString()) const
Set settings value.
bool setValue(const T &value, const QStringList &dynamicKeyPartList) const
Set settings value.
virtual bool checkValuePrivate(const T &value) const
Check if the value is valid.
T formerValue(const QString &dynamicKeyPart=QString()) const
Returns the former value.
T valueWithDefaultOverride(const T &defaultValueOverride, const QStringList &dynamicKeyPartList) const
Returns the settings value with a defaultValueOverride for the dynamicKeyPartList.
T formerValue(const QStringList &dynamicKeyPartList) const
Returns the former value Returns the current value (or default) if there is no former value.
Represents a settings entry and provides methods for reading and writing settings values.
bool copyValueFromKey(const QString &key, bool removeSettingAtKey=false) const
Copies the value from a given key if it exists.
Qgis::SettingsOptions options() const
Returns the settings options.
bool hasChanged() const
Returns true if the setting was changed during the current QGIS session.
QVariant defaultValueAsVariant() const
Returns settings default value.
QString description() const
Returns the settings entry description.
static QSettings & userSettings()
Returns a reference to the thread-local QSettings instance used internally by all QgsSettingsEntry op...
QgsSettingsTreeNode * parent() const
Returns the parent tree element.
Q_DECL_DEPRECATED int section() const
Returns settings section.
virtual bool checkValueVariant(const QVariant &value) const
Returns true if the given value is valid towards the setting definition.
bool setVariantValue(const QVariant &value, const QString &dynamicKeyPart=QString()) const
Set settings value.
QString name() const
Returns the name of the settings.
static void setupUserSettings(const QString &profilePath)
Configures QSettings to use IniFormat at the given profilePath so that each thread's QSettings instan...
QVariant formerValueAsVariant(const QString &dynamicKeyPart) const
Returns the former value of the settings if it has been enabled in the options.
QVariant valueAsVariant(const QString &dynamicKeyPart=QString()) const
Returns settings value with.
QString key(const QString &dynamicKeyPart=QString()) const
Returns settings entry key.
static QStringList dynamicKeyPartToList(const QString &dynamicKeyPart)
Transforms a dynamic key part string to list.
QVariant valueAsVariantWithDefaultOverride(const QVariant &defaultValueOverride, const QString &dynamicKeyPart=QString()) const
Returns settings value with a defaultValueOverride.
virtual Qgis::SettingsType settingsType() const
Returns the settings entry type.
QgsSettingsEntryBase(const QString &key, const QString §ion, const QVariant &defaultValue=QVariant(), const QString &description=QString(), Qgis::SettingsOptions options=Qgis::SettingsOptions())
Constructor for QgsSettingsEntryBase.
A boolean settings entry.
An integer settings entry.
A string list settings entry.
A string list settings entry.
A variant settings entry.
Custom exception class for settings related exceptions.
A tree node for the settings tree to help organizing and introspecting the tree.
QString key() const
Returns the key of the node (without its parents).
QgsSettingsTreeNode * parent() const
Returns the parent of the node or nullptr if it does not exists.
#define SIP_CONVERT_TO_SUBCLASS_CODE(code)
#define SIP_THROW(name,...)