aboutsummaryrefslogtreecommitdiffstats
path: root/dive.h
diff options
context:
space:
mode:
authorGravatar Salvador Cuñat <salvador.cunat@gmail.com>2014-07-16 07:23:34 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-07-16 07:38:31 -0700
commit7eb422d98837b3cfb289a66fa0f3a8f78f222001 (patch)
tree213eb95ccb4817e6383e548493cfc0dfb4bea81b /dive.h
parent5a34261fece16518e9318548a00db2bd52669732 (diff)
downloadsubsurface-7eb422d98837b3cfb289a66fa0f3a8f78f222001.tar.gz
Change in logic while aplying gps fixes to dives
We were actually searching dives which match the dowloaded position fixes. So we're also trying to take into account if the fix is automatic or no based on a limited amount of predefined strings (bad idea, as the user can change in companion app settings the predefined string). This way, in actual implementation, if program concludes that a fix has been manually got or, simply, the user is unlucky enough to have all the position fixes out of the dive time, find_dive_n_near() function will pair fix and dive in an ordered way (1st fix -> 1st dive; 2nd fix -> 2nd dive ...) which is probably erroneous, except for manual position fixes. BTW actual implementation can't pair the same gps position with more than one dive, which would be the case, e.g. in repetitive dives while at anchor in the same point. The patch changes the logic: - Search positions for defined dives (instead of dives for defined positions) without care if position has manually or automatically been set. - Only take care of those dives that don't have a position yet. - It makes two assumptions: a.- If the position fix has been taken during the dive time, is correct. If there are more than one inside the dive time, takes the first one (closest to the DC's reported time). b.- If not during diving time, the correct one is the nearest fix before the dive begins (also the usual case if manually fixed from the smartphone just before jump into the water). But will work too if there is only one fix *in SAME_GROUP range* after the dive (another usual case). - Finally, as copy_gps_location() in dive.h is used only here, let it take care of naming the dive if user hasn't named it yet. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'dive.h')
-rw-r--r--dive.h3
1 files changed, 3 insertions, 0 deletions
diff --git a/dive.h b/dive.h
index 4978f4f9a..e2442818c 100644
--- a/dive.h
+++ b/dive.h
@@ -326,6 +326,9 @@ static inline void copy_gps_location(struct dive *from, struct dive *to)
if (from && to) {
to->latitude.udeg = from->latitude.udeg;
to->longitude.udeg = from->longitude.udeg;
+ if (!to->location) {
+ to->location = strdup(from->location);
+ }
}
}