diff options
-rw-r--r-- | core/prefs-macros.h | 44 |
1 files changed, 33 insertions, 11 deletions
diff --git a/core/prefs-macros.h b/core/prefs-macros.h index 53361a19f..ca5b1c7d9 100644 --- a/core/prefs-macros.h +++ b/core/prefs-macros.h @@ -8,79 +8,101 @@ #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 + prefs.units.field = default_prefs.units.field; \ + } #define GET_UNIT3(name, field, f, l, type) \ + { \ v = s.value(QString(name)); \ if (v.isValid() && v.toInt() >= (f) && v.toInt() <= (l)) \ prefs.units.field = (type)v.toInt(); \ else \ - prefs.units.field = default_prefs.units.field + prefs.units.field = default_prefs.units.field; \ + } #define GET_UNIT_BOOL(name, field) \ + { \ v = s.value(QString(name)); \ if (v.isValid()) \ prefs.units.field = v.toBool(); \ else \ - prefs.units.field = default_prefs.units.field + 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 + 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 + 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 + 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 + 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 + prefs.field = defval; \ + } #define GET_TXT(name, field) \ + { \ v = s.value(QString(name)); \ if (v.isValid()) \ prefs.field = copy_qstring(v.toString()); \ else \ - prefs.field = copy_string(default_prefs.field) + prefs.field = copy_string(default_prefs.field); \ + } #define SAVE_OR_REMOVE_SPECIAL(_setting, _default, _compare, _value) \ + { \ if (_compare != _default) \ s.setValue(_setting, _value); \ else \ - s.remove(_setting) + s.remove(_setting); \ + } #define SAVE_OR_REMOVE(_setting, _default, _value) \ + { \ if (_value != _default) \ s.setValue(_setting, _value); \ else \ - s.remove(_setting) + s.remove(_setting); \ + } #endif // PREFSMACROS_H |