summaryrefslogtreecommitdiffstats
path: root/core
diff options
context:
space:
mode:
Diffstat (limited to 'core')
-rw-r--r--core/settings/qPrefCloudStorage.cpp10
-rw-r--r--core/settings/qPrefDisplay.cpp2
-rw-r--r--core/settings/qPrefPrivate.cpp7
-rw-r--r--core/settings/qPrefPrivate.h13
4 files changed, 17 insertions, 15 deletions
diff --git a/core/settings/qPrefCloudStorage.cpp b/core/settings/qPrefCloudStorage.cpp
index 68e0bd027..1f6f23ece 100644
--- a/core/settings/qPrefCloudStorage.cpp
+++ b/core/settings/qPrefCloudStorage.cpp
@@ -35,8 +35,8 @@ void qPrefCloudStorage::set_cloud_base_url(const QString& value)
if (value != prefs.cloud_base_url) {
// only free and set if not default
if (prefs.cloud_base_url != default_prefs.cloud_base_url) {
- COPY_TXT(cloud_base_url, value);
- COPY_TXT(cloud_git_url, QString(prefs.cloud_base_url) + "/git");
+ qPrefPrivate::copy_txt(&prefs.cloud_base_url, value);
+ qPrefPrivate::copy_txt(&prefs.cloud_git_url, QString(prefs.cloud_base_url) + "/git");
}
disk_cloud_base_url(true);
@@ -55,7 +55,7 @@ void qPrefCloudStorage::set_cloud_git_url(const QString& value)
if (value != prefs.cloud_git_url) {
// only free and set if not default
if (prefs.cloud_git_url != default_prefs.cloud_git_url) {
- COPY_TXT(cloud_git_url, value);
+ qPrefPrivate::copy_txt(&prefs.cloud_git_url, value);
}
disk_cloud_git_url(true);
emit cloud_git_url_changed(value);
@@ -73,7 +73,7 @@ void qPrefCloudStorage::set_cloud_storage_newpassword(const QString& value)
if (value == prefs.cloud_storage_newpassword)
return;
- COPY_TXT(cloud_storage_newpassword, value);
+ qPrefPrivate::copy_txt(&prefs.cloud_storage_newpassword, value);
// NOT saved on disk, because it is only temporary
emit cloud_storage_newpassword_changed(value);
@@ -83,7 +83,7 @@ GET_PREFERENCE_TXT(CloudStorage, cloud_storage_password);
void qPrefCloudStorage::set_cloud_storage_password(const QString& value)
{
if (value != prefs.cloud_storage_password) {
- COPY_TXT(cloud_storage_password,value);
+ qPrefPrivate::copy_txt(&prefs.cloud_storage_password, value);
disk_cloud_storage_password(true);
emit cloud_storage_password_changed(value);
}
diff --git a/core/settings/qPrefDisplay.cpp b/core/settings/qPrefDisplay.cpp
index 55a0129a9..e11930b5e 100644
--- a/core/settings/qPrefDisplay.cpp
+++ b/core/settings/qPrefDisplay.cpp
@@ -35,7 +35,7 @@ void qPrefDisplay::set_divelist_font(const QString& value)
if (newValue != prefs.divelist_font &&
!subsurface_ignore_font(qPrintable(newValue))) {
- COPY_TXT(divelist_font, value);
+ qPrefPrivate::copy_txt(&prefs.divelist_font, value);
disk_divelist_font(true);
qApp->setFont(QFont(newValue));
diff --git a/core/settings/qPrefPrivate.cpp b/core/settings/qPrefPrivate.cpp
index 53b99c4e5..32b00ee79 100644
--- a/core/settings/qPrefPrivate.cpp
+++ b/core/settings/qPrefPrivate.cpp
@@ -9,3 +9,10 @@ qPrefPrivate *qPrefPrivate::instance()
static qPrefPrivate *self = new qPrefPrivate;
return self;
}
+
+void qPrefPrivate::copy_txt(const char **name, const QString& string)
+{
+ free((void *)*name);
+ *name = copy_qstring(string);
+}
+
diff --git a/core/settings/qPrefPrivate.h b/core/settings/qPrefPrivate.h
index e4131e9e4..558333990 100644
--- a/core/settings/qPrefPrivate.h
+++ b/core/settings/qPrefPrivate.h
@@ -3,7 +3,6 @@
#define QPREFPRIVATE_H
// Header used by all qPref<class> implementations to avoid duplicating code
-
#include <QSettings>
#include <QVariant>
#include <QObject>
@@ -18,17 +17,13 @@ public:
QSettings setting;
+ // Helper functions
+ static void copy_txt(const char **name, const QString& string);
+
private:
qPrefPrivate(QObject *parent = NULL);
};
-//****** Macros to be used in the set functions ******
-#define COPY_TXT(name, string) \
-{ \
- free((void *)prefs.name); \
- prefs.name = copy_qstring(string); \
-}
-
//****** Macros to be used in the disk functions, which are special ******
#define LOADSYNC_BOOL(name, field) \
{ \
@@ -191,7 +186,7 @@ void qPref ## usegroup::set_ ## field (int value) \
void qPref ## usegroup::set_ ## field (const QString& value) \
{ \
if (value != prefs.field) { \
- COPY_TXT(field, value); \
+ qPrefPrivate::instance()->copy_txt(&prefs.field, value); \
disk_ ## field(true); \
emit field ## _changed(value); \
} \