From 3cd698361c3c1a8c8f5e455799d954e76f68d6bc Mon Sep 17 00:00:00 2001 From: jan Iversen Date: Mon, 6 Aug 2018 19:25:06 +0200 Subject: core: create qPrefGeocoding from SettingsObjectWrapper Update set/get functions to follow common name scheme: - get function have same name as in struct preferences - set function have set_ - signal function have _changed one class one .h/.cpp is the C++ idiom. Having load/sync of each variable in 1 functions (in contrast to the distributed way SettingsObjectWrapper handles it) secures the same storage name is used. Having the set/get/load/sync functions grouped together makes it easier to get an overview. REMARK: this commit only defines the class, it is not active in production Signed-off-by: Jan Iversen --- core/settings/qPref.h | 1 + core/settings/qPrefGeocoding.cpp | 72 ++++++++++++++++++++++++++++++++++++++++ core/settings/qPrefGeocoding.h | 45 +++++++++++++++++++++++++ core/settings/qPrefPrivate.h | 1 + 4 files changed, 119 insertions(+) create mode 100644 core/settings/qPrefGeocoding.cpp create mode 100644 core/settings/qPrefGeocoding.h (limited to 'core/settings') diff --git a/core/settings/qPref.h b/core/settings/qPref.h index bb304f0d5..7bd6e2076 100644 --- a/core/settings/qPref.h +++ b/core/settings/qPref.h @@ -11,6 +11,7 @@ #include "qPrefDiveComputer.h" #include "qPrefDivePlanner.h" #include "qPrefFacebook.h" +#include "qPrefGeocoding.h" #include "qPrefLanguage.h" #include "qPrefLocationService.h" #include "qPrefProxy.h" diff --git a/core/settings/qPrefGeocoding.cpp b/core/settings/qPrefGeocoding.cpp new file mode 100644 index 000000000..8d7553e53 --- /dev/null +++ b/core/settings/qPrefGeocoding.cpp @@ -0,0 +1,72 @@ +// SPDX-License-Identifier: GPL-2.0 +#include "qPref.h" +#include "qPrefPrivate.h" + +static const QString group = QStringLiteral("geocoding"); + +qPrefGeocoding::qPrefGeocoding(QObject *parent) : QObject(parent) +{ +} +qPrefGeocoding *qPrefGeocoding::instance() +{ + static qPrefGeocoding *self = new qPrefGeocoding; + return self; +} + +void qPrefGeocoding::loadSync(bool doSync) +{ + disk_first_taxonomy_category(doSync); + disk_second_taxonomy_category(doSync); + disk_third_taxonomy_category(doSync); +} + + +void qPrefGeocoding::set_first_taxonomy_category(taxonomy_category value) +{ + if (value != prefs.geocoding.category[0]) { + prefs.geocoding.category[0] = value; + disk_first_taxonomy_category(true); + emit first_taxonomy_category_changed(value); + } +} +void qPrefGeocoding::disk_first_taxonomy_category(bool doSync) +{ + if (doSync) + qPrefPrivate::instance()->setting.setValue(group + "/cat0", prefs.geocoding.category[0]); + else + prefs.geocoding.category[0] = (enum taxonomy_category)qPrefPrivate::instance()->setting.value(group + "/cat0", default_prefs.geocoding.category[0]).toInt(); +} + + +void qPrefGeocoding::set_second_taxonomy_category(taxonomy_category value) +{ + if (value != prefs.geocoding.category[1]) { + prefs.geocoding.category[1] = value; + disk_second_taxonomy_category(true); + emit second_taxonomy_category_changed(value); + } +} +void qPrefGeocoding::disk_second_taxonomy_category(bool doSync) +{ + if (doSync) + qPrefPrivate::instance()->setting.setValue(group + "/cat1", prefs.geocoding.category[1]); + else + prefs.geocoding.category[1] = (enum taxonomy_category)qPrefPrivate::instance()->setting.value(group + "/cat1", default_prefs.geocoding.category[1]).toInt(); +} + + +void qPrefGeocoding::set_third_taxonomy_category(taxonomy_category value) +{ + if (value != prefs.geocoding.category[2]) { + prefs.geocoding.category[2] = value; + disk_third_taxonomy_category(true); + emit third_taxonomy_category_changed(value); + } +} +void qPrefGeocoding::disk_third_taxonomy_category(bool doSync) +{ + if (doSync) + qPrefPrivate::instance()->setting.setValue(group + "/cat2", prefs.geocoding.category[2]); + else + prefs.geocoding.category[2] = (enum taxonomy_category)qPrefPrivate::instance()->setting.value(group + "/cat2", default_prefs.geocoding.category[2]).toInt(); +} diff --git a/core/settings/qPrefGeocoding.h b/core/settings/qPrefGeocoding.h new file mode 100644 index 000000000..ce3eba2e5 --- /dev/null +++ b/core/settings/qPrefGeocoding.h @@ -0,0 +1,45 @@ +// SPDX-License-Identifier: GPL-2.0 +#ifndef QPREFGEOCODING_H +#define QPREFGEOCODING_H +#include "core/pref.h" + +#include + + +class qPrefGeocoding : public QObject { + Q_OBJECT + Q_PROPERTY(taxonomy_category first_taxonomy_category READ first_taxonomy_category WRITE set_first_taxonomy_category NOTIFY first_taxonomy_category_changed); + Q_PROPERTY(taxonomy_category second_taxonomy_category READ second_taxonomy_category WRITE set_second_taxonomy_category NOTIFY second_taxonomy_category_changed); + Q_PROPERTY(taxonomy_category third_taxonomy_category READ third_taxonomy_category WRITE set_third_taxonomy_category NOTIFY third_taxonomy_category_changed); + +public: + qPrefGeocoding(QObject *parent = NULL); + static qPrefGeocoding *instance(); + + // Load/Sync local settings (disk) and struct preference + void loadSync(bool doSync); + void load() { loadSync(false); } + void sync() { loadSync(true); } + +public: + taxonomy_category first_taxonomy_category() { return prefs.geocoding.category[0]; } + taxonomy_category second_taxonomy_category() { return prefs.geocoding.category[1]; } + taxonomy_category third_taxonomy_category() { return prefs.geocoding.category[2]; } + +public slots: + void set_first_taxonomy_category(taxonomy_category value); + void set_second_taxonomy_category(taxonomy_category value); + void set_third_taxonomy_category(taxonomy_category value); + +signals: + void first_taxonomy_category_changed(taxonomy_category value); + void second_taxonomy_category_changed(taxonomy_category value); + void third_taxonomy_category_changed(taxonomy_category value); + +private: + void disk_first_taxonomy_category(bool doSync); + void disk_second_taxonomy_category(bool doSync); + void disk_third_taxonomy_category(bool doSync); +}; + +#endif diff --git a/core/settings/qPrefPrivate.h b/core/settings/qPrefPrivate.h index 5a34acdc8..beef0e639 100644 --- a/core/settings/qPrefPrivate.h +++ b/core/settings/qPrefPrivate.h @@ -20,6 +20,7 @@ public: friend class qPrefDiveComputer; friend class qPrefDivePlanner; friend class qPrefFacebook; + friend class qPrefGeocoding; friend class qPrefLanguage; friend class qPrefLocationService; friend class qPrefProxy; -- cgit v1.2.3-70-g09d2