From d7f7dd7773f69261c2c168b1cba7d330208bb9ad Mon Sep 17 00:00:00 2001 From: Petr Kubanek Date: Tue, 11 Jun 2024 16:43:06 +0200 Subject: [PATCH] Data consistency checks in vmsrawdump --- utils/vmsrawdump.cpp | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/utils/vmsrawdump.cpp b/utils/vmsrawdump.cpp index be93b6f..16dbb31 100644 --- a/utils/vmsrawdump.cpp +++ b/utils/vmsrawdump.cpp @@ -138,9 +138,17 @@ void dump_file(const char *filename) { std::cout << std::endl; auto micros_d = duration_cast(system_clock::now().time_since_epoch()).count(); + long int old_micros = 0; while (!file.eof()) { file.read(reinterpret_cast(µs_d), sizeof(micros_d)); + + if (old_micros >= micros_d) { + std::cerr << "Recorded timestamps in file " << filename << " aren't increasing (" + << old_micros << " >= " << micros_d << "), skipping rest of the file!" << std::endl; + return; + } + microseconds micros(micros_d); seconds sec = duration_cast(micros); micros -= sec; @@ -159,6 +167,8 @@ void dump_file(const char *filename) { } std::cout << std::endl; + + old_micros = micros_d; } } catch (const std::ios_base::failure &e) { if (file.eof()) {