X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fsettings.cpp;h=2330f45fed49934ce1e0eb78e770aecefb36d476;hp=2d79ffe3767bf0c269f8665fc8b5e2847e211d17;hb=00e1a9c29e792ba4d65dba21b7ba04131bcb13bc;hpb=54dd5d1f5ae8a4170ed7bfdbeb546e8340540cc3 diff --git a/src/common/settings.cpp b/src/common/settings.cpp index 2d79ffe3..2330f45f 100644 --- a/src/common/settings.cpp +++ b/src/common/settings.cpp @@ -30,6 +30,7 @@ const int VERSION = 1; /// Settings version for backwords/forwards const int VERSION_MINOR_INITIAL = 1; /// Initial settings version for compatible changes QHash Settings::settingsCache; +QHash Settings::settingsKeyPersistedCache; QHash Settings::settingsChangeNotifier; #ifdef Q_OS_MAC @@ -186,6 +187,7 @@ void Settings::setLocalValue(const QString &key, const QVariant &data) QString normKey = normalizedKey(group, key); create_qsettings; s.setValue(normKey, data); + setCacheKeyPersisted(normKey, true); setCacheValue(normKey, data); if (hasNotifier(normKey)) { emit notifier(normKey)->valueChanged(data); @@ -193,25 +195,37 @@ void Settings::setLocalValue(const QString &key, const QVariant &data) } -const QVariant &Settings::localValue(const QString &key, const QVariant &def) +QVariant Settings::localValue(const QString &key, const QVariant &def) { QString normKey = normalizedKey(group, key); if (!isCached(normKey)) { create_qsettings; + // Since we're loading from settings anyways, cache whether or not the key exists on disk + setCacheKeyPersisted(normKey, s.contains(normKey)); + // Cache key value setCacheValue(normKey, s.value(normKey, def)); } - return cacheValue(normKey); + if (cacheKeyPersisted(normKey)) { + return cacheValue(normKey); + } else { + // Don't return possibly wrong cached values + // A key gets cached with the first default value requested and never changes afterwards + return def; + } } bool Settings::localKeyExists(const QString &key) { QString normKey = normalizedKey(group, key); - if (isCached(normKey)) - return true; + if (!isKeyPersistedCached(normKey)) { + create_qsettings; + // Cache whether or not key exists on disk + // We can't cache key value as we don't know the default + setCacheKeyPersisted(normKey, s.contains(normKey)); + } - create_qsettings; - return s.contains(normKey); + return cacheKeyPersisted(normKey); } @@ -225,6 +239,9 @@ void Settings::removeLocalKey(const QString &key) if (isCached(normKey)) { settingsCache.remove(normKey); } + if (isKeyPersistedCached(normKey)) { + settingsKeyPersistedCache.remove(normKey); + } if (hasNotifier(normKey)) { emit notifier(normKey)->valueChanged({}); }