diff options
author | jan Iversen <jan@casacondor.com> | 2020-01-07 14:31:49 +0100 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2020-01-20 09:55:26 -0800 |
commit | 6e065506317e2595a0df19dba147576d392c9506 (patch) | |
tree | 9061a855826df17a5acf6cb4b207c205694db7dd /core/settings/qPrefUnit.h | |
parent | 13b2b9f19c3f9ecb41565c5eab07d590071dede6 (diff) | |
download | subsurface-6e065506317e2595a0df19dba147576d392c9506.tar.gz |
core/settings:: remove string functions for units
Remove string version of unit_system, duration_units, length, pressure,
temperature, vertical_speed_time, and volume, including tests and make signals
strongly typed in C++
Signed-off-by: jan Iversen <jan@casacondor.com>
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'core/settings/qPrefUnit.h')
-rw-r--r-- | core/settings/qPrefUnit.h | 66 |
1 files changed, 17 insertions, 49 deletions
diff --git a/core/settings/qPrefUnit.h b/core/settings/qPrefUnit.h index 467117ef2..5e81bd77a 100644 --- a/core/settings/qPrefUnit.h +++ b/core/settings/qPrefUnit.h @@ -9,15 +9,7 @@ class qPrefUnits : public QObject { Q_OBJECT Q_PROPERTY(bool coordinates_traditional READ coordinates_traditional WRITE set_coordinates_traditional NOTIFY coordinates_traditionalChanged) - Q_PROPERTY(QString duration_units READ duration_units WRITE set_duration_units NOTIFY duration_unitsStringChanged) - Q_PROPERTY(QString length READ length WRITE set_length NOTIFY lengthStringChanged) - Q_PROPERTY(QString pressure READ pressure WRITE set_pressure NOTIFY pressureStringChanged) Q_PROPERTY(bool show_units_table READ show_units_table WRITE set_show_units_table NOTIFY show_units_tableChanged) - Q_PROPERTY(QString temperature READ temperature WRITE set_temperature NOTIFY temperatureStringChanged) - Q_PROPERTY(QString unit_system READ unit_system WRITE set_unit_system NOTIFY unit_systemStringChanged) - Q_PROPERTY(QString vertical_speed_time READ vertical_speed_time WRITE set_vertical_speed_time NOTIFY vertical_speed_timeStringChanged) - Q_PROPERTY(QString volume READ volume WRITE set_volume NOTIFY volumeStringChanged) - Q_PROPERTY(QString weight READ weight WRITE set_weight NOTIFY weightStringChanged) public: static qPrefUnits *instance(); @@ -29,63 +21,40 @@ public: public: static bool coordinates_traditional() { return prefs.coordinates_traditional; } - static QString duration_units(); - static QString length(); - static QString pressure(); + static units::DURATION duration_units() { return prefs.units.duration_units; } + static units::LENGTH length() { return prefs.units.length; } + static units::PRESSURE pressure() { return prefs.units.pressure; } static bool show_units_table() { return prefs.units.show_units_table; } - static QString temperature(); - static QString unit_system(); - static QString vertical_speed_time(); - static QString volume(); - static QString weight(); + static unit_system_values unit_system() { return prefs.unit_system; } + static units::TEMPERATURE temperature() { return prefs.units.temperature; } + static units::TIME vertical_speed_time() { return prefs.units.vertical_speed_time; } + static units::VOLUME volume() { return prefs.units.volume; } + static units::WEIGHT weight() { return prefs.units.weight; } public slots: static void set_coordinates_traditional(bool value); static void set_duration_units(units::DURATION value); - static void set_duration_units(const QString& value); static void set_length(units::LENGTH value); - static void set_length(const QString& value); static void set_pressure(units::PRESSURE value); - static void set_pressure(const QString& value); static void set_show_units_table(bool value); static void set_temperature(units::TEMPERATURE value); - static void set_temperature(const QString& value); static void set_unit_system(unit_system_values value); - static void set_unit_system(const QString& value); static void set_vertical_speed_time(units::TIME value); - static void set_vertical_speed_time(const QString& value); static void set_volume(units::VOLUME value); - static void set_volume(const QString& value); static void set_weight(units::WEIGHT value); - static void set_weight(const QString& value); signals: - // Normally the same signal name are used with different parameters: - // void weightChanged(int value); - // void weightChanged(const QString& value); - // This works perfect, however connect() cannot automatically determine - // which signal to catch, for that purpose SIGNAL() / SLOT() macros are used, - // since they include the parameter type. - // However there is a design decision, not to use the macros, so - // signal must have unique names. void coordinates_traditionalChanged(bool value); - void duration_unitsChanged(int value); - void duration_unitsStringChanged(const QString& value); - void lengthChanged(int value); - void lengthStringChanged(const QString& value); - void pressureChanged(int value); - void pressureStringChanged(const QString& value); + void duration_unitsChanged(units::DURATION value); + void lengthChanged(units::LENGTH value); + void pressureChanged(units::PRESSURE value); void show_units_tableChanged(bool value); - void temperatureChanged(int value); - void temperatureStringChanged(const QString& value); - void unit_systemChanged(int value); - void unit_systemStringChanged(const QString& value); - void vertical_speed_timeChanged(int value); - void vertical_speed_timeStringChanged(const QString& value); - void volumeChanged(int value); - void volumeStringChanged(const QString& value); - void weightChanged(int value); - void weightStringChanged(const QString& value); + void temperatureChanged(units::TEMPERATURE value); + void unit_systemChanged(unit_system_values value); + void vertical_speed_timeChanged(units::TIME value); + void volumeChanged(units::VOLUME value); + void weightChanged(units::WEIGHT value); + private: qPrefUnits() {} @@ -100,5 +69,4 @@ private: static void disk_volume(bool doSync); static void disk_weight(bool doSync); }; - #endif |