summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Linus Torvalds <torvalds@linux-foundation.org>2011-10-19 09:25:47 -0700
committerGravatar Linus Torvalds <torvalds@linux-foundation.org>2011-10-19 09:25:47 -0700
commit9dce78c89fe77a107af7a8c962da19780485c3e2 (patch)
tree3aacf276213e4952dbb12be3ce1810839a4d070c
parent2b3d39f6fc9814fb1190dd5b69396defe4cc85cf (diff)
downloadsubsurface-9dce78c89fe77a107af7a8c962da19780485c3e2.tar.gz
Don't overwrite the end pressure with sample data if one already exists
If we have en explicit end pressure in the dive information, we should not change it just because we also have some samples. The sample data may not be complete (read: "Linus wireless connection dropped during the dive again, and he fixed up the end pressure manually afterwards"). The beginning pressure already works correctly, because it will only use the sample data for the first sample if no pressure existed before. Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r--dive.c31
1 files changed, 26 insertions, 5 deletions
diff --git a/dive.c b/dive.c
index deb72fc80..0341d0992 100644
--- a/dive.c
+++ b/dive.c
@@ -140,26 +140,46 @@ static void update_temperature(temperature_t *temperature, int new)
}
}
-static void fixup_pressure(struct dive *dive, struct sample *sample)
+/*
+ * If you have more than 32 cylinders, you'd better have a 64-bit build.
+ * And if you have more than 64 cylinders, you need to use another tool,
+ * or fix this up to do something odd.
+ */
+static unsigned long fixup_pressure(struct dive *dive, struct sample *sample, unsigned long flags)
{
+ unsigned long mask;
unsigned int pressure, index;
cylinder_t *cyl;
pressure = sample->cylinderpressure.mbar;
if (!pressure)
- return;
+ return flags;
index = sample->cylinderindex;
if (index >= MAX_CYLINDERS)
- return;
+ return flags;
cyl = dive->cylinder + index;
if (!cyl->start.mbar)
cyl->start.mbar = pressure;
+ /*
+ * If we already have an end pressure, without
+ * ever having seen a sample for this cylinder,
+ * that means that somebody set the end pressure
+ * by hand
+ */
+ mask = 1ul << index;
+ if (cyl->end.mbar) {
+ if (!(flags & mask))
+ return flags;
+ }
+ flags |= mask;
+
/* we need to handle the user entering beginning and end tank pressures
* - maybe even IF we have samples. But for now if we have air pressure
* data in the samples, we use that instead of the minimum
* if (!cyl->end.mbar || pressure < cyl->end.mbar)
*/
- cyl->end.mbar = pressure;
+ cyl->end.mbar = pressure;
+ return flags;
}
struct dive *fixup_dive(struct dive *dive)
@@ -171,6 +191,7 @@ struct dive *fixup_dive(struct dive *dive)
int maxdepth = 0, mintemp = 0;
int lastdepth = 0;
int lasttemp = 0;
+ unsigned long flags = 0;
for (i = 0; i < dive->samples; i++) {
struct sample *sample = dive->sample + i;
@@ -188,7 +209,7 @@ struct dive *fixup_dive(struct dive *dive)
maxdepth = depth;
}
- fixup_pressure(dive, sample);
+ flags = fixup_pressure(dive, sample, flags);
if (temp) {
/*