aboutsummaryrefslogtreecommitdiffstats
path: root/uemis-downloader.c
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2013-02-08 12:53:32 +1100
committerGravatar Dirk Hohndel <dirk@hohndel.org>2013-02-08 12:53:32 +1100
commit5692131a79f2adcfabc30804ccac62e077df402d (patch)
treea9c703f4a9166cc6aada2893f3e050375d83d401 /uemis-downloader.c
parentb18c34373f2c5e90e1d311f28e5a9ae12c6d1be3 (diff)
downloadsubsurface-5692131a79f2adcfabc30804ccac62e077df402d.tar.gz
Fix Uemis downloader to download all matching dive infomration
The Uemis SDA returns the data for each dive from several different databases. And oddly, the getDive data uses a different key than the getDivelog data. We have always compensated for that by looking up the correct key and applying the data to that dive, but unfortunately we didn't adjust the loop to correctly retrieve the getDive data for the dives that were downloaded. So depending on how big the offset between those two keys was we wouldn't get all of the necessary data. With this change we try one, calculate the offset and then restart the loop. Insane, but appears to be the only way to make this work. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'uemis-downloader.c')
-rw-r--r--uemis-downloader.c36
1 files changed, 28 insertions, 8 deletions
diff --git a/uemis-downloader.c b/uemis-downloader.c
index c20ebb838..91eae3145 100644
--- a/uemis-downloader.c
+++ b/uemis-downloader.c
@@ -631,7 +631,7 @@ static void parse_tag(struct dive *dive, char *tag, char *val)
* index into yet another data store that we read out later. In order to
* correctly populate the location and gps data from that we need to remember
* the adresses of those fields for every dive that references the divespot. */
-static void process_raw_buffer(uint32_t deviceid, char *inbuf, char **max_divenr, gboolean keep_number)
+static void process_raw_buffer(uint32_t deviceid, char *inbuf, char **max_divenr, gboolean keep_number, int *for_dive)
{
char *buf = strdup(inbuf);
char *tp, *bp, *tag, *type, *val;
@@ -643,6 +643,8 @@ static void process_raw_buffer(uint32_t deviceid, char *inbuf, char **max_divenr
int s, nr_sections = 0;
struct dive *dive = NULL;
+ if (for_dive)
+ *for_dive = -1;
bp = buf + 1;
tp = next_token(&bp);
if (strcmp(tp, "divelog") == 0) {
@@ -697,6 +699,8 @@ static void process_raw_buffer(uint32_t deviceid, char *inbuf, char **max_divenr
} else if (!log && ! strcmp(tag, "logfilenr")) {
/* this one tells us which dive we are adding data to */
dive = get_dive_by_diveid(atoi(val), deviceid);
+ if (for_dive)
+ *for_dive = atoi(val);
} else if (!log && dive && ! strcmp(tag, "divespot_id")) {
track_divespot(val, dive->dc.diveid, &dive->location, &dive->latitude, &dive->longitude);
} else if (dive) {
@@ -752,7 +756,7 @@ static char *do_uemis_download(struct argument_block *args)
{
const char *mountpath = args->mountpath;
char *newmax = NULL;
- int start, end, i;
+ int start, end, i, offset;
uint32_t deviceidnr;
char objectid[10];
char *deviceid = NULL;
@@ -795,7 +799,7 @@ static char *do_uemis_download(struct argument_block *args)
success = uemis_get_answer(mountpath, "getDivelogs", 3, 0, &result);
/* process the buffer we have assembled */
if (mbuf)
- process_raw_buffer(deviceidnr, mbuf, &newmax, keep_number);
+ process_raw_buffer(deviceidnr, mbuf, &newmax, keep_number, NULL);
if (once) {
char *t = first_object_id_val(mbuf);
if (t && atoi(t) > start)
@@ -825,15 +829,31 @@ static char *do_uemis_download(struct argument_block *args)
fprintf(debugfile, "done: read from object_id %d to %d\n", start, end);
#endif
free(newmax);
- for (i = start; i < end; i++) {
- snprintf(objectid, sizeof(objectid), "%d", i);
+ offset = 0;
+ for (i = start; i <= end; i++) {
+ snprintf(objectid, sizeof(objectid), "%d", i + offset);
param_buff[2] = objectid;
#if UEMIS_DEBUG & 2
- fprintf(debugfile, "getDive %d\n", i);
+ fprintf(debugfile, "getDive %d, object_id %s\n", i, objectid);
#endif
+ /* there is no way I have found to directly get the dive information
+ * for dive #i as the object_id and logfilenr can be different in the
+ * getDive call; so we get the first one, compare the actual divenr
+ * with the one that we wanted, calculate the offset and try again.
+ * What an insane design... */
success = uemis_get_answer(mountpath, "getDive", 3, 0, &result);
- if (mbuf)
- process_raw_buffer(deviceidnr, mbuf, &newmax, FALSE);
+ if (mbuf) {
+ int divenr;
+ process_raw_buffer(deviceidnr, mbuf, &newmax, FALSE, &divenr);
+ if (divenr > -1 && divenr != i) {
+ offset = i - divenr;
+#if UEMIS_DEBUG & 2
+ fprintf(debugfile, "got dive %d -> trying again with offset %d\n", divenr, offset);
+#endif
+ i = start - 1;
+ continue;
+ }
+ }
if (!success || import_thread_cancelled)
break;
}