mirror of
https://github.com/subsurface/subsurface.git
synced 2025-01-19 22:35:27 +00:00
1f03a8be81
Remove two erroneous comments stating that a function-local QSettings variable should not be static because it is initialized too early. Scoped static variables are initialized when execution first hits the statement. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
38 lines
942 B
C++
38 lines
942 B
C++
// SPDX-License-Identifier: GPL-2.0
|
|
#include "qPrefPrivate.h"
|
|
#include "core/subsurface-string.h"
|
|
|
|
#include <QSettings>
|
|
|
|
void qPrefPrivate::copy_txt(const char **name, const QString &string)
|
|
{
|
|
free((void *)*name);
|
|
*name = copy_qstring(string);
|
|
}
|
|
|
|
QString keyFromGroupAndName(QString group, QString name)
|
|
{
|
|
QString slash = (group.endsWith('/') || name.startsWith('/')) ? "" : "/";
|
|
return group + slash + name;
|
|
}
|
|
|
|
void qPrefPrivate::propSetValue(const QString &key, const QVariant &value, const QVariant &defaultValue)
|
|
{
|
|
QSettings s;
|
|
bool isDefault = false;
|
|
if (value.isValid() && value.type() == QVariant::Double)
|
|
isDefault = IS_FP_SAME(value.toDouble(), defaultValue.toDouble());
|
|
else
|
|
isDefault = (value == defaultValue);
|
|
|
|
if (!isDefault)
|
|
s.setValue(key, value);
|
|
else
|
|
s.remove(key);
|
|
}
|
|
|
|
QVariant qPrefPrivate::propValue(const QString &key, const QVariant &defaultValue)
|
|
{
|
|
QSettings s;
|
|
return s.value(key, defaultValue);
|
|
}
|