diff options
Diffstat (limited to 'core')
-rw-r--r-- | core/settings/qPref_private.h | 82 |
1 files changed, 57 insertions, 25 deletions
diff --git a/core/settings/qPref_private.h b/core/settings/qPref_private.h index 96a3b1e5e..e2e8f350c 100644 --- a/core/settings/qPref_private.h +++ b/core/settings/qPref_private.h @@ -4,69 +4,101 @@ // Header used by all qPref<class> implementations to avoid duplicating code -#include <QObject> #include <QSettings> #include <QVariant> +#include <QObject> #include "core/qthelper.h" +//****** Macros to be used in the set functions ****** #define COPY_TXT(name, string) \ { \ free((void *)prefs.name); \ prefs.name = copy_qstring(string); \ } -#define LOADSYNC_INT(name, field) \ +//****** Macros to be used in the disk functions, which are special ****** +#define LOADSYNC_BOOL(name, field) \ { \ - QSettings s; \ - if (doSync) \ - s.setValue(group + name, prefs.field); \ + if (doSync) \ + setting.setValue(group + name, prefs.field); \ else \ - prefs.field = s.value(group + name, default_prefs.field).toInt(); \ + prefs.field = setting.value(group + name, default_prefs.field).toBool(); \ } -#define LOADSYNC_INT_DEF(name, field, defval) \ +#define LOADSYNC_DOUBLE(name, field) \ { \ - QSettings s; \ if (doSync) \ - s.setValue(group + name, prefs.field); \ + setting.setValue(group + name, prefs.field); \ else \ - prefs.field = s.value(group + name, defval).toInt(); \ + prefs.field = setting.value(group + name, default_prefs.field).toDouble(); \ } #define LOADSYNC_ENUM(name, type, field) \ { \ - QSettings s; \ if (doSync) \ - s.setValue(group + name, prefs.field); \ + setting.setValue(group + name, prefs.field); \ else \ - prefs.field = (enum type)s.value(group + name, default_prefs.field).toInt(); \ + prefs.field = (enum type)setting.value(group + name, default_prefs.field).toInt(); \ } -#define LOADSYNC_BOOL(name, field) \ +#define LOADSYNC_INT(name, field) \ { \ - QSettings s; \ - if (doSync) \ - s.setValue(group + name, prefs.field); \ + if (doSync) \ + setting.setValue(group + name, prefs.field); \ else \ - prefs.field = s.value(group + name, default_prefs.field).toBool(); \ + prefs.field = setting.value(group + name, default_prefs.field).toInt(); \ } -#define LOADSYNC_DOUBLE(name, field) \ +#define LOADSYNC_INT_DEF(name, field, defval) \ { \ - QSettings s; \ if (doSync) \ - s.setValue(group + name, prefs.field); \ + setting.setValue(group + name, prefs.field); \ else \ - prefs.field = s.value(group + name, default_prefs.field).toDouble(); \ + prefs.field = setting.value(group + name, defval).toInt(); \ } #define LOADSYNC_TXT(name, field) \ { \ - QSettings s; \ if (doSync) \ - s.setValue(group + name, prefs.field); \ + setting.setValue(group + name, prefs.field); \ else \ - prefs.field = copy_qstring(s.value(group + name, default_prefs.field).toString()); \ + prefs.field = copy_qstring(setting.value(group + name, default_prefs.field).toString()); \ } +//******* Macros to generate disk function +#define DISK_LOADSYNC_BOOL(class, name, field) \ +void qPref ## class::disk_ ## field(bool doSync) \ +{ \ + LOADSYNC_BOOL(name, field); \ +} + +#define DISK_LOADSYNC_DOUBLE(class, name, field) \ +void qPref ## class::disk_ ## field(bool doSync) \ +{ \ + LOADSYNC_DOUBLE(name, field); \ +} + +#define DISK_LOADSYNC_ENUM(class, name, type, field) \ +void qPref ## class::disk_ ## field(bool doSync) \ +{ \ + LOADSYNC_ENUM(name, type, field); \ +} + +#define DISK_LOADSYNC_INT(class, name, field) \ +void qPref ## class::disk_ ## field(bool doSync) \ +{ \ + LOADSYNC_DOUBLE(name, field); \ +} + +#define DISK_LOADSYNC_INT_DEF(class, name, field, defval) \ +void qPref ## class::disk_ ## field(bool doSync) \ +{ \ + LOADSYNC_INT_DEF(name, field, defval); \ +} + +#define DISK_LOADSYNC_TXT(class, name, field) \ +void qPref ## class::disk_ ## field(bool doSync) \ +{ \ + LOADSYNC_TXT(name, field); \ +} #endif |