summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2014-08-05 21:21:31 -0700
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-08-05 21:21:31 -0700
commitd85d08e14f9ed2b39e0d4d2cdc772e26f02fef78 (patch)
treebbf65c4d0a159db69c5551c84e17927d6ddd4567
parent4d775fd049f72af0b94c37d729246ae992472d3a (diff)
downloadsubsurface-d85d08e14f9ed2b39e0d4d2cdc772e26f02fef78.tar.gz
Data validation
Instead of refusing cylinder pressure data let's just mark it as red when the values don't seem to make sense. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--qt-ui/models.cpp20
1 files changed, 18 insertions, 2 deletions
diff --git a/qt-ui/models.cpp b/qt-ui/models.cpp
index 8963c1287..7fc941558 100644
--- a/qt-ui/models.cpp
+++ b/qt-ui/models.cpp
@@ -95,6 +95,21 @@ QVariant CylindersModel::data(const QModelIndex &index, int role) const
cylinder_t *cyl = &displayed_dive.cylinder[index.row()];
switch (role) {
+ case Qt::BackgroundRole: {
+ switch (index.column()) {
+ // mark the cylinder start / end pressure in red if the values
+ // seem implausible
+ case START:
+ case END:
+ if ((cyl->start.mbar && !cyl->end.mbar) ||
+ (cyl->end.mbar && cyl->start.mbar <= cyl->end.mbar))
+ ret = REDORANGE1_HIGH_TRANS;
+ else
+ ret = WHITE1;
+ break;
+ }
+ break;
+ }
case Qt::FontRole: {
QFont font = defaultModelFont();
switch (index.column()) {
@@ -235,13 +250,14 @@ bool CylindersModel::setData(const QModelIndex &index, const QVariant &value, in
}
break;
case START:
- if (CHANGED() && (!cyl->end.mbar || string_to_pressure(vString.toUtf8().data()).mbar >= cyl->end.mbar)) {
+ if (CHANGED()) {
cyl->start = string_to_pressure(vString.toUtf8().data());
changed = true;
}
break;
case END:
- if (CHANGED() && (!cyl->start.mbar || string_to_pressure(vString.toUtf8().data()).mbar <= cyl->start.mbar)) {
+ if (CHANGED()) {
+ //&& (!cyl->start.mbar || string_to_pressure(vString.toUtf8().data()).mbar <= cyl->start.mbar)) {
cyl->end = string_to_pressure(vString.toUtf8().data());
changed = true;
}