summaryrefslogtreecommitdiffstats
path: root/core/dive.c
diff options
context:
space:
mode:
authorGravatar Stefan Fuchs <sfuchs@gmx.de>2017-11-29 10:16:00 +0100
committerGravatar Jan Mulder <jlmulder@xs4all.nl>2018-02-27 09:17:57 +0100
commit4cbf8b87a3586d15cff9770d1e3fc9f813498037 (patch)
tree1e524f5f07080f4d3d19034218e5c762d0104781 /core/dive.c
parentcd5e17cf79c2f1eb896efd0436c103221de446ae (diff)
downloadsubsurface-4cbf8b87a3586d15cff9770d1e3fc9f813498037.tar.gz
Updated strategy for removing cylinders
Change the strategy when to allow cylinder removal from a dive: - Not remove when cylinder has gas switch events, in any other cases allow removal - Remove this whole "cylinder with same gas" thing being a criteria for cylinder removal When removing a cylinder which has corresponding pressure info in samples, also remove this pressure info from the samples. Signed-off-by: Stefan Fuchs <sfuchs@gmx.de>
Diffstat (limited to 'core/dive.c')
-rw-r--r--core/dive.c14
1 files changed, 12 insertions, 2 deletions
diff --git a/core/dive.c b/core/dive.c
index 528cf9efa..c4a903eec 100644
--- a/core/dive.c
+++ b/core/dive.c
@@ -2072,7 +2072,7 @@ static void dc_cylinder_renumber(struct dive *dive, struct divecomputer *dc, int
if (mapping[0] > 0)
add_initial_gaschange(dive, dc);
- /* Remap the sensor indexes */
+ /* Remap or delete the sensor indexes */
for (i = 0; i < dc->samples; i++) {
struct sample *s = dc->sample + i;
int j;
@@ -2081,8 +2081,18 @@ static void dc_cylinder_renumber(struct dive *dive, struct divecomputer *dc, int
int sensor;
sensor = mapping[s->sensor[j]];
- if (sensor >= 0)
+ if (sensor == -1) {
+ // Remove sensor and gas pressure info
+ if (i == 0) {
+ s->sensor[j] = 0;
+ s->pressure[j].mbar = 0;
+ } else {
+ s->sensor[j] = s[-1].sensor[j];
+ s->pressure[j].mbar = s[-1].pressure[j].mbar;
+ }
+ } else {
s->sensor[j] = sensor;
+ }
}
}