Skip to content

Commit 72e51f0

Browse files
committed
Shearwater: Add Stack Timer Information.
Add the configured stack run time and the remaining stack run time at the start and end of the dive as extra information. Signed-off-by: Michael Keller <[email protected]>
1 parent 8922147 commit 72e51f0

File tree

1 file changed

+18
-0
lines changed

1 file changed

+18
-0
lines changed

src/shearwater_predator_parser.c

+18
Original file line numberDiff line numberDiff line change
@@ -497,6 +497,8 @@ shearwater_predator_parser_cache (shearwater_predator_parser_t *parser)
497497

498498
unsigned int offset = headersize;
499499
unsigned int length = size - footersize;
500+
unsigned int stack_time_total_s = 0;
501+
unsigned int stack_time_remaining_s;
500502
while (offset + parser->samplesize <= length) {
501503
// Ignore empty samples.
502504
if (array_isequal (data + offset, parser->samplesize, 0x00)) {
@@ -680,6 +682,14 @@ shearwater_predator_parser_cache (shearwater_predator_parser_t *parser)
680682
tank[1].pressure_reserve = array_uint16_be(data + offset + 17);
681683
}
682684
} else if (type == LOG_RECORD_OPENING_6) {
685+
if (logversion >= 11) {
686+
stack_time_total_s = array_uint16_be(data + offset + 1);
687+
if (stack_time_total_s > 0) {
688+
dc_field_add_string_fmt(&parser->cache, "Configured stack time [hh:mm:ss]", "%d:%02d:%02d", stack_time_total_s / 3600, (stack_time_total_s / 60) % 60, stack_time_total_s % 60);
689+
stack_time_remaining_s = array_uint16_be(data + offset + 3);
690+
dc_field_add_string_fmt(&parser->cache, "Remaining stack time at start [hh:mm:ss]", "%d:%02d:%02d", stack_time_remaining_s / 3600, (stack_time_remaining_s / 60) % 60, stack_time_remaining_s % 60);
691+
}
692+
}
683693
if (logversion >= 13) {
684694
tank[0].enabled = data[offset + 19];
685695
memcpy (tank[0].name, data + offset + 20, sizeof (tank[0].name));
@@ -704,6 +714,14 @@ shearwater_predator_parser_cache (shearwater_predator_parser_t *parser)
704714
}
705715
}
706716
} else if (type >= LOG_RECORD_CLOSING_0 && type <= LOG_RECORD_CLOSING_7) {
717+
if (type == LOG_RECORD_CLOSING_6) {
718+
if (logversion >= 11) {
719+
if (stack_time_total_s > 0) {
720+
stack_time_remaining_s = array_uint16_be(data + offset + 3);
721+
dc_field_add_string_fmt(&parser->cache, "Remaining stack time at end [hh:mm]", "%d:%02d:%02d", stack_time_remaining_s / 3600, (stack_time_remaining_s / 60) % 60, stack_time_remaining_s % 60);
722+
}
723+
}
724+
}
707725
// Closing record
708726
parser->closing[type - LOG_RECORD_CLOSING_0] = offset;
709727
} else if (type == LOG_RECORD_FINAL) {

0 commit comments

Comments
 (0)