From a7ca27d0712d1e73893c541aabcaaf68aac7afc7 Mon Sep 17 00:00:00 2001 From: Linus Torvalds Date: Tue, 29 Sep 2020 11:36:26 -0700 Subject: [PATCH] Prefer "GPS1" for divecomputer download dive site resolution I think we only have one dive computer that supports GPS data right now: the Garmin Descent Mk1. It reports the dive coordinates as "GPS1" and "GPS2" for the entry point and exit point respectively. Often GPS1 is missing, because the dive computer may not have gotten a GPS lock before the diver jumped into the water, so when that happens we'll use GPS2 for the dive site location. But when GPS1 exists, we should prefer that. And that's what we already did in logic in dc_get_gps_location(), but for the initial dive site created at download time, we just picked any divecomputer reported string that started with "GPS". And since GPS2 is reported after GPS1 by the Garmin Descent, it would end up overwriting the entry point that we _should_ have preferred. Add the same kind of "explicitly prefer GPS1" logic to the initial dive download case as we already had elsewhere. Reported-by: @brysconsulting Signed-off-by: Linus Torvalds --- core/libdivecomputer.c | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/core/libdivecomputer.c b/core/libdivecomputer.c index a35c0f908..b56daeb81 100644 --- a/core/libdivecomputer.c +++ b/core/libdivecomputer.c @@ -607,6 +607,15 @@ static void parse_string_field(device_data_t *devdata, struct dive *dive, dc_fie char *line = (char *) str->value; location_t location; + /* Do we already have a divesite? */ + if (dive->dive_site) { + /* + * "GPS1" always takes precedence, anything else + * we'll just pick the first "GPS*" that matches. + */ + if (strcmp(str->desc, "GPS1") != 0) + return; + } parse_location(line, &location); if (location.lat.udeg && location.lon.udeg) {