Skip to content
Snippets Groups Projects
Commit 15ef6ad0 authored by Friedemann Kleint's avatar Friedemann Kleint
Browse files

Designer: Use core settings instead of keeping QSettings instance.

parent 5cfb1941
No related branches found
No related tags found
No related merge requests found
......@@ -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;
}
......@@ -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
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment