summaryrefslogtreecommitdiffstats
path: root/core/divelist.c
diff options
context:
space:
mode:
authorGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2018-10-06 09:21:27 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2018-10-07 05:41:48 +0300
commitc32e71e64d97016d201aea26f0623de6cd65d74d (patch)
treed2dbd6a326701aba1e031a5f6508a5d811e2a34f /core/divelist.c
parentcec0b703652ffb4ab53fd792bee0cbf095b38cca (diff)
downloadsubsurface-c32e71e64d97016d201aea26f0623de6cd65d74d.tar.gz
Dive information: fix surface interval calculation
The old surface interval calculation had fundamental issues: 1) process_all_dives(), which calculates the statistics over *all* dives was used to get the pointer to the previous dive. 2) If two dives in the table had the same time, one of those would have been considered the "previous" dive. 3) If the dive, for which the surface interval is calculated is not yet in the table, no previous dive would be determined. Fix all this by creating a get_surface_interval() function and removing the "get previous dive" functionality of process_all_dives(). Remove the process_all_dives() call from TabDiveInformation::updateData(). Reported-by: Jan Mulder <jlmulder@xs4all.nl> Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'core/divelist.c')
-rw-r--r--core/divelist.c29
1 files changed, 29 insertions, 0 deletions
diff --git a/core/divelist.c b/core/divelist.c
index 84290e6b6..94adc92dc 100644
--- a/core/divelist.c
+++ b/core/divelist.c
@@ -1420,3 +1420,32 @@ void sort_table(struct dive_table *table)
{
qsort(table->dives, table->nr, sizeof(struct dive *), sortfn);
}
+
+/*
+ * Calculate surface interval for dive starting at "when". Currently, we
+ * might display dives which are not yet in the divelist, therefore the
+ * input parameter is a timestamp.
+ * If the given dive starts during a different dive, the surface interval
+ * is 0. If we can't determine a surface interval (first dive), <0 is
+ * returned. This does *not* consider pathological cases such as dives
+ * that happened inside other dives. The interval will always be calculated
+ * with respect to the dive that started previously.
+ */
+timestamp_t get_surface_interval(timestamp_t when)
+{
+ int i;
+ timestamp_t prev_end;
+
+ /* find previous dive. might want to use a binary search. */
+ for (i = dive_table.nr - 1; i >= 0; --i) {
+ if (dive_table.dives[i]->when < when)
+ break;
+ }
+ if (i < 0)
+ return -1;
+
+ prev_end = dive_endtime(dive_table.dives[i]);
+ if (prev_end > when)
+ return 0;
+ return when - prev_end;
+}