mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
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>
This commit is contained in:
parent
13b2b9f19c
commit
6e06550631
6 changed files with 60 additions and 183 deletions
|
@ -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
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue