summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Linus Torvalds <torvalds@linux-foundation.org>2014-01-09 10:34:25 +0800
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-01-09 15:46:03 +0800
commita79ddde1b9b4d2149c0e2a34a4f63a6ab5ae176d (patch)
treedaf8238add863b9b970ca9ce9ee678964a4ce0f1
parent39fb3b2c13d5d8383340f08dff893553111f6b7c (diff)
downloadsubsurface-a79ddde1b9b4d2149c0e2a34a4f63a6ab5ae176d.tar.gz
Add unit-aware cylinder size string parserc
Whittling down on the string parsing that doesn't check user-specified units. Still need to handle temperatures (and will do percentages to match the pattern too), but this is getting us closer to always honoring user-specified units. With this you can say that you have a "10l" cylinder at "3000psi", and it will do the right thing (it's basically a 72 cuft cylinder in imperial measurements). Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--dive.h1
-rw-r--r--qt-ui/models.cpp64
2 files changed, 42 insertions, 23 deletions
diff --git a/dive.h b/dive.h
index a9df1a09f..d1f9797fe 100644
--- a/dive.h
+++ b/dive.h
@@ -802,6 +802,7 @@ extern double strtod_flags(const char *str, const char **ptr, unsigned int flags
extern weight_t string_to_weight(const char *str);
extern depth_t string_to_depth(const char *str);
extern pressure_t string_to_pressure(const char *str);
+extern volume_t string_to_volume(const char *str, pressure_t workp);
#include "pref.h"
diff --git a/qt-ui/models.cpp b/qt-ui/models.cpp
index db180a27a..f411d282d 100644
--- a/qt-ui/models.cpp
+++ b/qt-ui/models.cpp
@@ -206,29 +206,15 @@ bool CylindersModel::setData(const QModelIndex& index, const QVariant& value, in
}
break;
case SIZE:
- if (CHANGED(toDouble, "cuft", "l")) {
- // if units are CUFT then this value is meaningless until we have working pressure
- if (vString.toDouble() != 0.0) {
- TankInfoModel *tanks = TankInfoModel::instance();
- QModelIndexList matches = tanks->match(tanks->index(0,0), Qt::DisplayRole, cyl->type.description);
- int mbar = cyl->type.workingpressure.mbar;
- int mliter;
-
- if (mbar && prefs.units.volume == prefs.units.CUFT) {
- double liters = cuft_to_l(vString.toDouble());
- liters /= bar_to_atm(mbar / 1000.0);
- mliter = rint(liters * 1000);
- } else {
- mliter = rint(vString.toDouble() * 1000);
- }
- if (cyl->type.size.mliter != mliter) {
- mark_divelist_changed(TRUE);
- cyl->type.size.mliter = mliter;
- if (!matches.isEmpty())
- tanks->setData(tanks->index(matches.first().row(), TankInfoModel::ML), cyl->type.size.mliter);
- }
- changed = true;
- }
+ if (CHANGED(data, "", "")) {
+ TankInfoModel *tanks = TankInfoModel::instance();
+ QModelIndexList matches = tanks->match(tanks->index(0,0), Qt::DisplayRole, cyl->type.description);
+
+ cyl->type.size = string_to_volume(vString.toUtf8().data(), cyl->type.workingpressure);
+ mark_divelist_changed(TRUE);
+ if (!matches.isEmpty())
+ tanks->setData(tanks->index(matches.first().row(), TankInfoModel::ML), cyl->type.size.mliter);
+ changed = true;
}
break;
case WORKINGPRESS:
@@ -513,6 +499,38 @@ psi:
return pressure;
}
+/* Imperial cylinder volumes need working pressure to be meaningful */
+volume_t string_to_volume(const char *str, pressure_t workp)
+{
+ const char *end;
+ double value = strtod_flags(str, &end, 0);
+ QString rest = QString(end).trimmed();
+ QString local_l = CylindersModel::tr("l");
+ QString local_cuft = CylindersModel::tr("cuft");
+ volume_t volume;
+
+ if (rest.startsWith("l") || rest.startsWith(local_l))
+ goto l;
+ if (rest.startsWith("cuft") || rest.startsWith(local_cuft))
+ goto cuft;
+ /*
+ * If we don't have explicit units, and there is no working
+ * pressure, we're going to assume "liter" even in imperial
+ * measurements.
+ */
+ if (!workp.mbar)
+ goto l;
+ if (prefs.units.volume == prefs.units.LITER)
+ goto l;
+cuft:
+ if (workp.mbar)
+ value /= bar_to_atm(workp.mbar / 1000.0);
+ value = cuft_to_l(value);
+l:
+ volume.mliter = rint(value * 1000);
+ return volume;
+}
+
bool WeightModel::setData(const QModelIndex& index, const QVariant& value, int role)
{
QString vString = value.toString();