summaryrefslogtreecommitdiffstats
path: root/dive.c
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2013-01-31 14:44:14 +1100
committerGravatar Dirk Hohndel <dirk@hohndel.org>2013-01-31 14:44:14 +1100
commit36b34bd5a5abdfabbd0f3ab0bb0d33e6e3477dd9 (patch)
treedaccb7c8d172fa8c87efd79de3620dedf4996772 /dive.c
parentaef211030db06b5394384f3b22a1226263506a9b (diff)
parent635c28923d28335bb7d39f95c17c2edbf16ee2ac (diff)
downloadsubsurface-36b34bd5a5abdfabbd0f3ab0bb0d33e6e3477dd9.tar.gz
Merge branch 'integrate-from-webservice'
Bring in the better implementation of merging gps locations from the webservice
Diffstat (limited to 'dive.c')
-rw-r--r--dive.c35
1 files changed, 35 insertions, 0 deletions
diff --git a/dive.c b/dive.c
index d86c7de2a..a0cb60ba6 100644
--- a/dive.c
+++ b/dive.c
@@ -1519,3 +1519,38 @@ struct dive *merge_dives(struct dive *a, struct dive *b, int offset, gboolean pr
fixup_dive(res);
return res;
}
+
+struct dive *find_dive_including(timestamp_t when)
+{
+ int i;
+ struct dive *dive;
+
+ /* binary search, anyone? Too lazy for now;
+ * also we always use the duration from the first divecomputer
+ * could this ever be a problem? */
+ for_each_dive(i, dive) {
+ if (dive->when <= when && when <= dive->when + dive->dc.duration.seconds)
+ return dive;
+ }
+ return NULL;
+}
+
+gboolean dive_within_time_range(struct dive *dive, timestamp_t when, timestamp_t offset)
+{
+ return when - offset <= dive->when && dive->when + dive->dc.duration.seconds <= when + offset;
+}
+
+/* find the n-th dive that is part of a group of dives within the offset around 'when'.
+ * How is that for a vague definition of what this function should do... */
+struct dive *find_dive_n_near(timestamp_t when, int n, timestamp_t offset)
+{
+ int i, j = 0;
+ struct dive *dive;
+
+ for_each_dive(i, dive) {
+ if (dive_within_time_range(dive, when, offset))
+ if (++j == n)
+ return dive;
+ }
+ return NULL;
+}