From 15ef6ad093a3a90c2de7f76cd7d0256c41d54fe4 Mon Sep 17 00:00:00 2001
From: Friedemann Kleint <Friedemann.Kleint@nokia.com>
Date: Thu, 19 May 2011 10:01:50 +0200
Subject: [PATCH] Designer: Use core settings instead of keeping QSettings
 instance.

---
 src/plugins/designer/settingsmanager.cpp | 50 ++++++++++++++++--------
 src/plugins/designer/settingsmanager.h   |  4 +-
 2 files changed, 34 insertions(+), 20 deletions(-)

diff --git a/src/plugins/designer/settingsmanager.cpp b/src/plugins/designer/settingsmanager.cpp
index c680dd327d1..9bf22940624 100644
--- a/src/plugins/designer/settingsmanager.cpp
+++ b/src/plugins/designer/settingsmanager.cpp
@@ -33,53 +33,69 @@
 #include "settingsmanager.h"
 #include "designerconstants.h"
 
+#include <coreplugin/icore.h>
+#include <utils/qtcassert.h>
+
+#include <QtCore/QSettings>
 #include <QtCore/QDebug>
 
 using namespace Designer::Internal;
 
+static inline QSettings *coreSettings()
+{
+    if (const Core::ICore *core = Core::ICore::instance())
+        return core->settings();
+    return 0;
+}
+
 void SettingsManager::beginGroup(const QString &prefix)
 {
-    if (Designer::Constants::Internal::debug > 1)
-        qDebug() << Q_FUNC_INFO << addPrefix(prefix);
-    m_settings.beginGroup(addPrefix(prefix));
+    QSettings *settings = coreSettings();
+    QTC_ASSERT(settings, return; )
+    settings->beginGroup(addPrefix(prefix));
 }
 
 void SettingsManager::endGroup()
 {
-    if (Designer::Constants::Internal::debug > 1)
-        qDebug() << Q_FUNC_INFO;
-    m_settings.endGroup();
+    QSettings *settings = coreSettings();
+    QTC_ASSERT(settings, return; )
+    settings->endGroup();
 }
 
 bool SettingsManager::contains(const QString &key) const
 {
-    return m_settings.contains(addPrefix(key));
+    const QSettings *settings = coreSettings();
+    QTC_ASSERT(settings, return false; )
+    return settings->contains(addPrefix(key));
 }
 
 void SettingsManager::setValue(const QString &key, const QVariant &value)
 {
-    if (Designer::Constants::Internal::debug > 1)
-        qDebug() << Q_FUNC_INFO  << addPrefix(key) << ": " << value;
-    m_settings.setValue(addPrefix(key), value);
+    QSettings *settings = coreSettings();
+    QTC_ASSERT(settings, return; )
+    settings->setValue(addPrefix(key), value);
 }
 
 QVariant SettingsManager::value(const QString &key, const QVariant &defaultValue) const
 {
-    QVariant result = m_settings.value(addPrefix(key), defaultValue);
-    if (Designer::Constants::Internal::debug > 1)
-        qDebug() << Q_FUNC_INFO << addPrefix(key) << ": " << result;
-    return result;
+    const QSettings *settings = coreSettings();
+    QTC_ASSERT(settings, return QVariant(); )
+    return settings->value(addPrefix(key), defaultValue);
 }
 
 void SettingsManager::remove(const QString &key)
 {
-    m_settings.remove(addPrefix(key));
+    QSettings *settings = coreSettings();
+    QTC_ASSERT(settings, return; )
+    settings->remove(addPrefix(key));
 }
 
 QString SettingsManager::addPrefix(const QString &name) const
 {
+    const QSettings *settings = coreSettings();
+    QTC_ASSERT(settings, return name; )
     QString result = name;
-    if (m_settings.group().isEmpty())
-        result.insert(0, QLatin1String("Designer"));
+    if (settings->group().isEmpty())
+        result.prepend(QLatin1String("Designer"));
     return result;
 }
diff --git a/src/plugins/designer/settingsmanager.h b/src/plugins/designer/settingsmanager.h
index 0c1291b7c70..d0f0cb1d63a 100644
--- a/src/plugins/designer/settingsmanager.h
+++ b/src/plugins/designer/settingsmanager.h
@@ -34,7 +34,6 @@
 #define SETTINGSMANAGER_H
 
 #include "qt_private/abstractsettings_p.h"
-#include <QtCore/QSettings>
 
 namespace Designer {
 namespace Internal {
@@ -50,12 +49,11 @@ public:
 
     virtual bool contains(const QString &key) const;
     virtual void setValue(const QString &key, const QVariant &value);
-    virtual QVariant value(const QString &key, const QVariant &defaultValue = QVariant()) const ;
+    virtual QVariant value(const QString &key, const QVariant &defaultValue = QVariant()) const;
     virtual void remove(const QString &key);
 
 private:
     QString addPrefix(const QString &name) const;
-    QSettings m_settings;
 };
 
 } // namespace Internal
-- 
GitLab