summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--libdivecomputer.c29
-rw-r--r--libdivecomputer.h2
2 files changed, 25 insertions, 6 deletions
diff --git a/libdivecomputer.c b/libdivecomputer.c
index 9ac50a4eb..fc1dad265 100644
--- a/libdivecomputer.c
+++ b/libdivecomputer.c
@@ -384,16 +384,18 @@ static void parse_string_field(struct dive *dive, dc_field_string_t *str)
}
if (!strcmp(str->desc, "Serial")) {
- if (!dive->dc.serial)
- dive->dc.serial = strdup(str->value);
+ fprintf(stderr, "string field \"Serial\": %s -- overwriting the existing serial of %s", str->value, dive->dc.serial);
+ dive->dc.serial = strdup(str->value);
+ /* should we just overwrite this whenever we have the "Serial" field?
+ * It's a much better deviceid then what we have so far... for now I'm leaving it as is */
if (!dive->dc.deviceid)
dive->dc.deviceid = calculate_string_hash(str->value);
return;
}
if (!strcmp(str->desc, "FW Version")) {
- if (!dive->dc.fw_version)
- dive->dc.fw_version = strdup(str->value);
+ fprintf(stderr, "string field \"FW Version\": %s -- overwriting the existing firware of %s", str->value, dive->dc.fw_version);
+ dive->dc.fw_version = strdup(str->value);
return;
}
@@ -439,6 +441,10 @@ static int dive_cb(const unsigned char *data, unsigned int size,
}
dive->dc.model = strdup(devdata->model);
dive->dc.deviceid = devdata->deviceid;
+ /* for now copy the "made up" strings converted from the 32bit numbers that libdivecomputer gives us;
+ * if the dive computer backend supports the DC_FIELD_STRING interface this will later be overwritten by the correct strings */
+ dive->dc.serial = copy_string(devdata->serial);
+ dive->dc.fw_version = copy_string(devdata->firmware);
dive->dc.diveid = calculate_diveid(fingerprint, fsize);
tm.tm_year = dt.year;
@@ -702,6 +708,7 @@ static void event_cb(dc_device_t *device, dc_event_type_t event, const void *dat
const dc_event_vendor_t *vendor = data;
device_data_t *devdata = userdata;
unsigned int serial;
+ char buffer[16];
switch (event) {
case DC_EVENT_WAITING:
@@ -731,7 +738,19 @@ static void event_cb(dc_device_t *device, dc_event_type_t event, const void *dat
if (!strcmp(devdata->vendor, "Suunto"))
serial = fixup_suunto_versions(devdata, devinfo);
devdata->deviceid = calculate_sha1(devinfo->model, devinfo->firmware, serial);
-
+ /* really, serial and firmware version are NOT numbers. We'll try to save them here
+ * in something that might work, but this really needs to be handled with the
+ * DC_FIELD_STRING interface instead */
+ if (serial != 0) {
+ snprintf(buffer, sizeof(buffer), "%04u-%04u", serial / 10000, serial % 10000);
+ devdata->serial = strdup(buffer);
+ fprintf(stderr, "libdc devinfo serial nr converted to %s\n", devdata->serial);
+ }
+ if (devinfo->firmware != 0) {
+ snprintf(buffer, sizeof(buffer), "%02u.%02u", devinfo->firmware / 100, devinfo->firmware % 100);
+ devdata->firmware = strdup(buffer);
+ fprintf(stderr, "libdc devinfo firmware version converted to %s\n", devdata->firmware);
+ }
break;
case DC_EVENT_CLOCK:
dev_info(devdata, translate("gettextFromC", "Event: systime=%" PRId64 ", devtime=%u\n"),
diff --git a/libdivecomputer.h b/libdivecomputer.h
index af51854a0..795c4ae85 100644
--- a/libdivecomputer.h
+++ b/libdivecomputer.h
@@ -19,7 +19,7 @@ typedef struct device_data_t
{
dc_descriptor_t *descriptor;
const char *vendor, *product, *devname;
- const char *model;
+ const char *model, *serial, *firmware;
uint32_t deviceid, diveid;
dc_device_t *device;
dc_context_t *context;