diff options
author | Anton Lundin <glance@acc.umu.se> | 2014-12-29 23:43:30 +0100 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2014-12-29 16:21:23 -0800 |
commit | ab208c8fefa278ab1a27770a8635ffde59ab5a24 (patch) | |
tree | 31c2b21e4d167c8dddab35da4f2029b8a20fe185 | |
parent | 3e5c1713d20a0719be9111a29bebaa6fe24f42af (diff) | |
download | subsurface-ab208c8fefa278ab1a27770a8635ffde59ab5a24.tar.gz |
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 <glance@acc.umu.se>
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r-- | parse-xml.c | 34 |
1 files 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; } |