diff options
author | 2018-09-20 12:03:09 -0700 | |
---|---|---|
committer | 2018-09-23 11:49:30 -0700 | |
commit | 77a5c9ac65d25000a64cf48fb2138c302cb0b116 (patch) | |
tree | 5159f2a6b9e83571b55c820babde5c99769c13c1 /core/settings/qPrefPrivate.h | |
parent | 5b37d87e2d63453443f25623abeb47aab765aaec (diff) | |
download | subsurface-77a5c9ac65d25000a64cf48fb2138c302cb0b116.tar.gz |
qPref: add ability to remember recently used dive computers
This does feel clumsy and complicated. This is a lot of special case
handling and a lot of boilerplate for something that really should be
quite simple.
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'core/settings/qPrefPrivate.h')
-rw-r--r-- | core/settings/qPrefPrivate.h | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/core/settings/qPrefPrivate.h b/core/settings/qPrefPrivate.h index 76bb8d77b..e78ca0c72 100644 --- a/core/settings/qPrefPrivate.h +++ b/core/settings/qPrefPrivate.h @@ -145,6 +145,20 @@ extern QString keyFromGroupAndName(QString group, QString name); current_state = QString(prefs.usestruct field); \ } \ } +#define DISK_LOADSYNC_TXT_EXT_ALT(usegroup, name, field, usestruct, alt) \ + void qPref##usegroup::disk_##field##alt(bool doSync) \ + { \ + static QString current_state; \ + if (doSync) { \ + if (current_state != QString(prefs.usestruct ## alt .field)) { \ + current_state = QString(prefs.usestruct ## alt .field); \ + qPrefPrivate::propSetValue(keyFromGroupAndName(group, name), prefs.usestruct ##alt .field, default_prefs.usestruct ##alt .field); \ + } \ + } else { \ + prefs.usestruct ##alt .field = copy_qstring(qPrefPrivate::propValue(keyFromGroupAndName(group, name), default_prefs.usestruct ##alt .field).toString()); \ + current_state = QString(prefs.usestruct ##alt .field); \ + } \ + } #define DISK_LOADSYNC_TXT(usegroup, name, field) \ DISK_LOADSYNC_TXT_EXT(usegroup, name, field, ) @@ -218,6 +232,17 @@ extern QString keyFromGroupAndName(QString group, QString name); emit instance()->field##Changed(value); \ } \ } + +#define SET_PREFERENCE_TXT_EXT_ALT(usegroup, field, usestruct, alt) \ + void qPref##usegroup::set_##field##alt(const QString &value) \ + { \ + if (value != prefs.usestruct ##alt .field) { \ + qPrefPrivate::copy_txt(&prefs.usestruct ##alt .field, value); \ + disk_##field##alt(true); \ + emit instance()->field##alt##Changed(value); \ + } \ + } + #define SET_PREFERENCE_TXT(usegroup, field) \ SET_PREFERENCE_TXT_EXT(usegroup, field, ) @@ -264,6 +289,10 @@ extern QString keyFromGroupAndName(QString group, QString name); #define HANDLE_PREFERENCE_TXT(usegroup, name, field) \ HANDLE_PREFERENCE_TXT_EXT(usegroup, name, field, ) +#define HANDLE_PREFERENCE_TXT_EXT_ALT(usegroup, name, field, usestruct, alt) \ + SET_PREFERENCE_TXT_EXT_ALT(usegroup, field, usestruct, alt); \ + DISK_LOADSYNC_TXT_EXT_ALT(usegroup, name, field, usestruct, alt); + #define HANDLE_PROP_QPOINTF(useclass, name, field) \ void qPref##useclass::set_##field(const QPointF& value) \ { \ |