mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
Parse info from the DLF header
After some reverse-engineering i managed to figure out a couple of values stored in the dive header. Signed-off-by: Anton Lundin <glance@acc.umu.se> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
parent
c5467b0d73
commit
c2be872f49
1 changed files with 34 additions and 3 deletions
37
parse-xml.c
37
parse-xml.c
|
@ -2537,13 +2537,43 @@ int parse_dlf_buffer(unsigned char *buffer, size_t size)
|
||||||
bool event, found;
|
bool event, found;
|
||||||
unsigned int time = 0;
|
unsigned int time = 0;
|
||||||
int i;
|
int i;
|
||||||
|
char serial[6];
|
||||||
|
|
||||||
target_table = &dive_table;
|
target_table = &dive_table;
|
||||||
|
|
||||||
/* Skipping the dive header for now */
|
|
||||||
ptr += 32;
|
|
||||||
|
|
||||||
dive_start();
|
dive_start();
|
||||||
|
divecomputer_start();
|
||||||
|
|
||||||
|
cur_dc->model = strdup("DLF import");
|
||||||
|
// (ptr[7] << 8) + ptr[6] Is "Serial"
|
||||||
|
snprintf(serial, sizeof(serial), "%d", (ptr[7] << 8) + ptr[6]);
|
||||||
|
cur_dc->serial = strdup(serial);
|
||||||
|
// Dive start time in seconds since 2000-01-01 12:00 UTC +0
|
||||||
|
cur_dc->when = (ptr[11] << 24) + (ptr[10] << 16) + (ptr[9] << 8) + ptr[8] + 946728000;
|
||||||
|
cur_dive->when = cur_dc->when;
|
||||||
|
|
||||||
|
cur_dc->duration.seconds = ((ptr[14] & 0xFE) << 16) + (ptr[13] << 8) + ptr[12];
|
||||||
|
|
||||||
|
// ptr[15] is dive type
|
||||||
|
if (0xc8 <= ptr[15] && ptr[15] <= 0xcf)
|
||||||
|
cur_dc->dctype = OC;
|
||||||
|
else if (0xd0 <= ptr[15] && ptr[15] <= 0xd7)
|
||||||
|
cur_dc->dctype = CCR;
|
||||||
|
else if (0xd8 <= ptr[15] && ptr[15] <= 0xdf)
|
||||||
|
cur_dc->dctype = CCR; // mCCR
|
||||||
|
else if (0xe0 <= ptr[15] && ptr[15] <= 0xe7)
|
||||||
|
cur_dc->dctype = OC; // Free diving
|
||||||
|
else if (0xe8 <= ptr[15] && ptr[15] <= 0xef)
|
||||||
|
cur_dc->dctype = OC; // Gauge
|
||||||
|
else if (0xf0 <= ptr[15] && ptr[15] <= 0xf7)
|
||||||
|
cur_dc->dctype = PSCR; // ASCR
|
||||||
|
else if (0xf8 <= ptr[15] && ptr[15] <= 0xff)
|
||||||
|
cur_dc->dctype = PSCR;
|
||||||
|
|
||||||
|
cur_dc->maxdepth.mm = ((ptr[21] << 8) + ptr[20]) * 10;
|
||||||
|
|
||||||
|
/* Done with parsing what we know about the dive header */
|
||||||
|
ptr += 32;
|
||||||
|
|
||||||
while (ptr < buffer + size) {
|
while (ptr < buffer + size) {
|
||||||
time = ((ptr[0] >> 4) & 0x0f) +
|
time = ((ptr[0] >> 4) & 0x0f) +
|
||||||
|
@ -2585,6 +2615,7 @@ int parse_dlf_buffer(unsigned char *buffer, size_t size)
|
||||||
}
|
}
|
||||||
ptr += 16;
|
ptr += 16;
|
||||||
}
|
}
|
||||||
|
divecomputer_end();
|
||||||
dive_end();
|
dive_end();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue