aboutsummaryrefslogtreecommitdiffstats
path: root/qt-models
diff options
context:
space:
mode:
Diffstat (limited to 'qt-models')
-rw-r--r--qt-models/cylindermodel.cpp16
-rw-r--r--qt-models/cylindermodel.h1
2 files changed, 17 insertions, 0 deletions
diff --git a/qt-models/cylindermodel.cpp b/qt-models/cylindermodel.cpp
index 6ea27f167..829639318 100644
--- a/qt-models/cylindermodel.cpp
+++ b/qt-models/cylindermodel.cpp
@@ -426,3 +426,19 @@ void CylindersModel::remove(const QModelIndex &index)
dc = dc->next;
}
}
+
+void CylindersModel::updateDecoDepths(pressure_t olddecopo2)
+{
+ pressure_t decopo2;
+ decopo2.mbar = prefs.decopo2;
+ for (int i = 0; i < MAX_CYLINDERS; i++) {
+ cylinder_t *cyl = &displayed_dive.cylinder[i];
+ struct gasmix *mygas = &cyl->gasmix;
+ /* If the gas's deco MOD matches the old pO2, it will have been automatically calculated and should be updated.
+ * If they don't match, we should leave the user entered depth as it is */
+ if (cyl->depth.mm == gas_mod(&cyl->gasmix, olddecopo2, &displayed_dive, M_OR_FT(3, 10)).mm) {
+ cyl->depth = gas_mod(&cyl->gasmix, decopo2, &displayed_dive, M_OR_FT(3, 10));
+ }
+ }
+ emit dataChanged(createIndex(0, 0), createIndex(MAX_CYLINDERS - 1, COLUMNS - 1));
+}
diff --git a/qt-models/cylindermodel.h b/qt-models/cylindermodel.h
index 7115dbe25..f2ae0125e 100644
--- a/qt-models/cylindermodel.h
+++ b/qt-models/cylindermodel.h
@@ -35,6 +35,7 @@ public:
void clear();
void updateDive();
void copyFromDive(struct dive *d);
+ void updateDecoDepths(pressure_t olddecopo2);
cylinder_t *cylinderAt(const QModelIndex &index);
bool changed;