From ab208c8fefa278ab1a27770a8635ffde59ab5a24 Mon Sep 17 00:00:00 2001 From: Anton Lundin Date: Mon, 29 Dec 2014 23:43:30 +0100 Subject: [PATCH] Restructure DLF sample parsing There are more event types than 1, so parse that as a unsigned char and not as a bool. Signed-off-by: Anton Lundin Signed-off-by: Dirk Hohndel --- parse-xml.c | 34 ++++++++++++++++++++-------------- 1 file changed, 20 insertions(+), 14 deletions(-) diff --git a/parse-xml.c b/parse-xml.c index 962980059..f0e6bc1b0 100644 --- a/parse-xml.c +++ b/parse-xml.c @@ -2534,7 +2534,8 @@ int parse_cobalt_buffer(sqlite3 *handle, const char *url, const char *buffer, in int parse_dlf_buffer(unsigned char *buffer, size_t size) { unsigned char *ptr = buffer; - bool event, found; + unsigned char event; + bool found; unsigned int time = 0; int i; char serial[6]; @@ -2584,16 +2585,23 @@ int parse_dlf_buffer(unsigned char *buffer, size_t size) ((ptr[1] << 4) & 0xff0) + (ptr[2] & 0x0f) * 3600; /* hours */ event = ptr[0] & 0x0f; - if (event == 1) { + switch (event) { + case 0: + /* Regular sample */ + sample_start(); + cur_sample->time.seconds = time; + cur_sample->depth.mm = ((ptr[4] & 0xff) + ((ptr[5] << 8) & 0xff00)) * 10; + sample_end(); + break; + case 1: /* dive event */ - switch(ptr[4]) { + event_start(); + cur_event.time.seconds = time; + switch (ptr[4]) { case 5: - event_start(); - cur_event.time.seconds = time; strcpy(cur_event.name, "gaschange"); cur_event.type = 25; cur_event.value = ptr[6]; - event_end(); found = false; for (i = 0; i < cur_cylinder_index; ++i) { @@ -2609,19 +2617,17 @@ int parse_dlf_buffer(unsigned char *buffer, size_t size) } break; case 6: - event_start(); - cur_event.time.seconds = time; strcpy(cur_event.name, "start"); - event_end(); break; default: fprintf(stderr, "DEBUG (event): %d at time %d\n", ptr[4], time); + break; } - } else { - sample_start(); - cur_sample->time.seconds = time; - cur_sample->depth.mm = ((ptr[4] & 0xff) + ((ptr[5] << 8) & 0xff00)) * 10; - sample_end(); + event_end(); + break; + default: + /* Unknown... */ + break; } ptr += 16; }