From 0002cd2d202c45d520f115280f98ba94c0028815 Mon Sep 17 00:00:00 2001 From: jan Iversen Date: Sun, 15 Jul 2018 18:15:40 +0200 Subject: core: create qPrefDiveComputer from SettingsObjectWrapper Update set/get functions to follow common name scheme: - get function have same name as in struct diveComputer - 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/qPrefDiveComputer.cpp | 34 ++++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 core/settings/qPrefDiveComputer.cpp (limited to 'core/settings/qPrefDiveComputer.cpp') diff --git a/core/settings/qPrefDiveComputer.cpp b/core/settings/qPrefDiveComputer.cpp new file mode 100644 index 000000000..04928dbfb --- /dev/null +++ b/core/settings/qPrefDiveComputer.cpp @@ -0,0 +1,34 @@ +// SPDX-License-Identifier: GPL-2.0 +#include "qPref.h" +#include "qPrefPrivate.h" + +static const QString group = QStringLiteral("DiveComputer"); + +qPrefDiveComputer::qPrefDiveComputer(QObject *parent) : QObject(parent) +{ +} +qPrefDiveComputer *qPrefDiveComputer::instance() +{ + static qPrefDiveComputer *self = new qPrefDiveComputer; + return self; +} + + +void qPrefDiveComputer::loadSync(bool doSync) +{ + disk_device(doSync); + disk_device_name(doSync); + disk_download_mode(doSync); + disk_product(doSync); + disk_vendor(doSync); +} + +HANDLE_PREFERENCE_TXT_EXT(DiveComputer, "/dive_computer_device", device, dive_computer.); + +HANDLE_PREFERENCE_TXT_EXT(DiveComputer, "/dive_computer_device_name", device_name, dive_computer.); + +HANDLE_PREFERENCE_INT_EXT(DiveComputer, "/dive_computer_download_mode", download_mode, dive_computer.); + +HANDLE_PREFERENCE_TXT_EXT(DiveComputer, "/dive_computer_product", product, dive_computer.); + +HANDLE_PREFERENCE_TXT_EXT(DiveComputer, "/dive_computer_vendor", vendor, dive_computer.); -- cgit v1.2.3-70-g09d2