summaryrefslogtreecommitdiffstats
path: root/subsurface-core/prefs-macros.h
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2015-11-02 19:54:34 -0800
committerGravatar Dirk Hohndel <dirk@hohndel.org>2015-11-02 19:54:34 -0800
commit8ea7f404574c2ee571d2dde6bb6be3791e962150 (patch)
tree6a050178bfc71bf10558968f2a3bc0a12d8c525f /subsurface-core/prefs-macros.h
parentb273c1b0ca7bfe933e7c83742f1610f6bbe3f4d3 (diff)
parentdf7818a9b8495285b4d9812e5d6d50d6f9c08813 (diff)
downloadsubsurface-8ea7f404574c2ee571d2dde6bb6be3791e962150.tar.gz
Merge branch 'cmakeAndPreferences'
Diffstat (limited to 'subsurface-core/prefs-macros.h')
-rw-r--r--subsurface-core/prefs-macros.h68
1 files changed, 68 insertions, 0 deletions
diff --git a/subsurface-core/prefs-macros.h b/subsurface-core/prefs-macros.h
new file mode 100644
index 000000000..fe459d3da
--- /dev/null
+++ b/subsurface-core/prefs-macros.h
@@ -0,0 +1,68 @@
+#ifndef PREFSMACROS_H
+#define PREFSMACROS_H
+
+#define SB(V, B) s.setValue(V, (int)(B->isChecked() ? 1 : 0))
+
+#define GET_UNIT(name, field, f, t) \
+ v = s.value(QString(name)); \
+ if (v.isValid()) \
+ prefs.units.field = (v.toInt() == (t)) ? (t) : (f); \
+ else \
+ prefs.units.field = default_prefs.units.field
+
+#define GET_BOOL(name, field) \
+ v = s.value(QString(name)); \
+ if (v.isValid()) \
+ prefs.field = v.toBool(); \
+ else \
+ prefs.field = default_prefs.field
+
+#define GET_DOUBLE(name, field) \
+ v = s.value(QString(name)); \
+ if (v.isValid()) \
+ prefs.field = v.toDouble(); \
+ else \
+ prefs.field = default_prefs.field
+
+#define GET_INT(name, field) \
+ v = s.value(QString(name)); \
+ if (v.isValid()) \
+ prefs.field = v.toInt(); \
+ else \
+ prefs.field = default_prefs.field
+
+#define GET_ENUM(name, type, field) \
+ v = s.value(QString(name)); \
+ if (v.isValid()) \
+ prefs.field = (enum type)v.toInt(); \
+ else \
+ prefs.field = default_prefs.field
+
+#define GET_INT_DEF(name, field, defval) \
+ v = s.value(QString(name)); \
+ if (v.isValid()) \
+ prefs.field = v.toInt(); \
+ else \
+ prefs.field = defval
+
+#define GET_TXT(name, field) \
+ v = s.value(QString(name)); \
+ if (v.isValid()) \
+ prefs.field = strdup(v.toString().toUtf8().constData()); \
+ else \
+ prefs.field = default_prefs.field
+
+#define SAVE_OR_REMOVE_SPECIAL(_setting, _default, _compare, _value) \
+ if (_compare != _default) \
+ s.setValue(_setting, _value); \
+ else \
+ s.remove(_setting)
+
+#define SAVE_OR_REMOVE(_setting, _default, _value) \
+ if (_value != _default) \
+ s.setValue(_setting, _value); \
+ else \
+ s.remove(_setting)
+
+#endif // PREFSMACROS_H
+