mirror of
https://github.com/Cockatrice/Cockatrice.git
synced 2026-07-04 20:43:54 -07:00
[SettingsManager] Properly handle multithreaded access again (#6844)
* [SettingsManager] Properly handle multithreaded access again * Add comment * Add batch write function --------- Co-authored-by: Lukas Brübach <Bruebach.Lukas@bdosecurity.de>
This commit is contained in:
parent
7c9fbe2be0
commit
19dbb17fb9
10 changed files with 88 additions and 12 deletions
|
|
@ -34,3 +34,17 @@ bool CardDatabaseSettings::isKnown(QString shortName) const
|
|||
{
|
||||
return getValue("isknown", "sets", std::move(shortName)).toBool();
|
||||
}
|
||||
|
||||
void CardDatabaseSettings::saveSets(const QVector<ICardSetPriorityController::SetSaveData> &data)
|
||||
{
|
||||
batchWrite([&](QSettings &s) {
|
||||
s.beginGroup("sets");
|
||||
for (const auto &entry : data) {
|
||||
s.beginGroup(entry.shortName);
|
||||
s.setValue("sortkey", entry.sortKey);
|
||||
s.setValue("enabled", entry.enabled);
|
||||
s.endGroup();
|
||||
}
|
||||
s.endGroup();
|
||||
});
|
||||
}
|
||||
|
|
@ -26,6 +26,8 @@ public:
|
|||
bool isEnabled(QString shortName) const override;
|
||||
bool isKnown(QString shortName) const override;
|
||||
|
||||
void saveSets(const QVector<SetSaveData> &data) override;
|
||||
|
||||
private:
|
||||
explicit CardDatabaseSettings(const QString &settingPath, QObject *parent = nullptr);
|
||||
};
|
||||
|
|
|
|||
|
|
@ -4,13 +4,20 @@ SettingsManager::SettingsManager(const QString &_settingPath,
|
|||
const QString &_defaultGroup,
|
||||
const QString &_defaultSubGroup,
|
||||
QObject *parent)
|
||||
: QObject(parent), defaultGroup(_defaultGroup), defaultSubGroup(_defaultSubGroup),
|
||||
settings(_settingPath, QSettings::IniFormat)
|
||||
: QObject(parent), settingPath(_settingPath), defaultGroup(_defaultGroup), defaultSubGroup(_defaultSubGroup)
|
||||
{
|
||||
}
|
||||
|
||||
QSettings SettingsManager::getSettings() const
|
||||
{
|
||||
// Do not store the QSettings instance in a field, as that is not threadsafe (see #6747)
|
||||
return QSettings(settingPath, QSettings::IniFormat);
|
||||
}
|
||||
|
||||
void SettingsManager::setValue(const QVariant &value, const QString &name)
|
||||
{
|
||||
auto settings = getSettings();
|
||||
|
||||
if (!defaultGroup.isEmpty()) {
|
||||
settings.beginGroup(defaultGroup);
|
||||
}
|
||||
|
|
@ -35,6 +42,8 @@ void SettingsManager::setValue(const QVariant &value,
|
|||
const QString &group,
|
||||
const QString &subGroup)
|
||||
{
|
||||
auto settings = getSettings();
|
||||
|
||||
if (!group.isEmpty()) {
|
||||
settings.beginGroup(group);
|
||||
}
|
||||
|
|
@ -56,6 +65,8 @@ void SettingsManager::setValue(const QVariant &value,
|
|||
|
||||
void SettingsManager::deleteValue(const QString &name)
|
||||
{
|
||||
auto settings = getSettings();
|
||||
|
||||
if (!defaultGroup.isEmpty()) {
|
||||
settings.beginGroup(defaultGroup);
|
||||
}
|
||||
|
|
@ -77,6 +88,8 @@ void SettingsManager::deleteValue(const QString &name)
|
|||
|
||||
void SettingsManager::deleteValue(const QString &name, const QString &group, const QString &subGroup)
|
||||
{
|
||||
auto settings = getSettings();
|
||||
|
||||
if (!group.isEmpty()) {
|
||||
settings.beginGroup(group);
|
||||
}
|
||||
|
|
@ -98,6 +111,8 @@ void SettingsManager::deleteValue(const QString &name, const QString &group, con
|
|||
|
||||
QVariant SettingsManager::getValue(const QString &name) const
|
||||
{
|
||||
auto settings = getSettings();
|
||||
|
||||
if (!defaultGroup.isEmpty()) {
|
||||
settings.beginGroup(defaultGroup);
|
||||
}
|
||||
|
|
@ -121,6 +136,8 @@ QVariant SettingsManager::getValue(const QString &name) const
|
|||
|
||||
QVariant SettingsManager::getValue(const QString &name, const QString &group, const QString &subGroup) const
|
||||
{
|
||||
auto settings = getSettings();
|
||||
|
||||
if (!group.isEmpty()) {
|
||||
settings.beginGroup(group);
|
||||
}
|
||||
|
|
@ -142,10 +159,21 @@ QVariant SettingsManager::getValue(const QString &name, const QString &group, co
|
|||
return value;
|
||||
}
|
||||
|
||||
void SettingsManager::batchWrite(std::function<void(QSettings &)> batchWriteFunction)
|
||||
{
|
||||
auto settings = getSettings();
|
||||
settings.setAtomicSyncRequired(false);
|
||||
batchWriteFunction(settings);
|
||||
settings.sync(); // single flush
|
||||
settings.setAtomicSyncRequired(true);
|
||||
}
|
||||
|
||||
/**
|
||||
* Calls sync on the underlying QSettings object
|
||||
*/
|
||||
void SettingsManager::sync()
|
||||
{
|
||||
auto settings = getSettings();
|
||||
|
||||
settings.sync();
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -23,14 +23,16 @@ public:
|
|||
|
||||
QVariant getValue(const QString &name) const;
|
||||
QVariant getValue(const QString &name, const QString &group, const QString &subGroup = QString()) const;
|
||||
void batchWrite(std::function<void(QSettings &)> batchWriteFunction);
|
||||
|
||||
void sync();
|
||||
|
||||
protected:
|
||||
QString settingPath;
|
||||
QString defaultGroup;
|
||||
QString defaultSubGroup;
|
||||
|
||||
mutable QSettings settings;
|
||||
QSettings getSettings() const;
|
||||
|
||||
void setValue(const QVariant &value, const QString &name);
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue