summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Anton Lundin <glance@acc.umu.se>2014-12-29 23:43:30 +0100
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-12-29 16:21:23 -0800
commitab208c8fefa278ab1a27770a8635ffde59ab5a24 (patch)
tree31c2b21e4d167c8dddab35da4f2029b8a20fe185
parent3e5c1713d20a0719be9111a29bebaa6fe24f42af (diff)
downloadsubsurface-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.c34
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;
}