mirror of
https://gitlab.com/pholy/OSCAR-code.git
synced 2025-04-05 10:40:42 +00:00
Report parsing failure when PRS1 sanity checks fail.
Remarkably, this resulted in nearly no changes to the test output. Only one session with 0 duration had its start/end times reset to 0, since it will no longer get imported.
This commit is contained in:
parent
26f6e15a75
commit
27c169e61e
@ -1049,13 +1049,6 @@ void PRS1Loader::ScanFiles(const QStringList & paths, int sessionid_base, Machin
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Parse the data chunks and read the files..
|
// Parse the data chunks and read the files..
|
||||||
if (fi.canonicalFilePath().isEmpty()) {
|
|
||||||
#if QT_VERSION < QT_VERSION_CHECK(5,12,0)
|
|
||||||
qWarning() << fi.fileName() << "canonicalFilePath is empty";
|
|
||||||
#else
|
|
||||||
qWarning() << fi << "cannonicalFilePath is empty";
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
QList<PRS1DataChunk *> Chunks = ParseFile(fi.canonicalFilePath());
|
QList<PRS1DataChunk *> Chunks = ParseFile(fi.canonicalFilePath());
|
||||||
|
|
||||||
for (int i=0; i < Chunks.size(); ++i) {
|
for (int i=0; i < Chunks.size(); ++i) {
|
||||||
@ -1067,7 +1060,7 @@ void PRS1Loader::ScanFiles(const QStringList & paths, int sessionid_base, Machin
|
|||||||
PRS1DataChunk * chunk = Chunks.at(i);
|
PRS1DataChunk * chunk = Chunks.at(i);
|
||||||
|
|
||||||
SessionID chunk_sid = chunk->sessionid;
|
SessionID chunk_sid = chunk->sessionid;
|
||||||
if (i > 0 || chunk_sid != sid) { // log multiple chunks in non-waveform files and session ID mismatches
|
if (i == 0 && chunk_sid != sid) { // log session ID mismatches
|
||||||
qDebug() << fi.canonicalFilePath() << chunk_sid;
|
qDebug() << fi.canonicalFilePath() << chunk_sid;
|
||||||
}
|
}
|
||||||
if (m->SessionExists(chunk_sid)) {
|
if (m->SessionExists(chunk_sid)) {
|
||||||
@ -1717,7 +1710,7 @@ bool PRS1DataChunk::ParseEventsF5V3(void)
|
|||||||
{
|
{
|
||||||
if (this->family != 5 || this->familyVersion != 3) {
|
if (this->family != 5 || this->familyVersion != 3) {
|
||||||
qWarning() << "ParseEventsF5V3 called with family" << this->family << "familyVersion" << this->familyVersion;
|
qWarning() << "ParseEventsF5V3 called with family" << this->family << "familyVersion" << this->familyVersion;
|
||||||
//break; // don't break to avoid changing behavior (for now)
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
EventDataType data0, data1, data2, data3, data4, data5;
|
EventDataType data0, data1, data2, data3, data4, data5;
|
||||||
@ -2437,7 +2430,7 @@ bool PRS1DataChunk::ParseEventsF3V6(void)
|
|||||||
|
|
||||||
if (this->family != 3 || this->familyVersion != 6) {
|
if (this->family != 3 || this->familyVersion != 6) {
|
||||||
qWarning() << "ParseEventsF3V6 called with family" << this->family << "familyVersion" << this->familyVersion;
|
qWarning() << "ParseEventsF3V6 called with family" << this->family << "familyVersion" << this->familyVersion;
|
||||||
//break; // don't break to avoid changing behavior (for now)
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
int t = 0;
|
int t = 0;
|
||||||
@ -2623,7 +2616,7 @@ bool PRS1DataChunk::ParseEventsF3V3(void)
|
|||||||
{
|
{
|
||||||
if (this->family != 3 || this->familyVersion != 3) {
|
if (this->family != 3 || this->familyVersion != 3) {
|
||||||
qWarning() << "ParseEventsF3V3 called with family" << this->family << "familyVersion" << this->familyVersion;
|
qWarning() << "ParseEventsF3V3 called with family" << this->family << "familyVersion" << this->familyVersion;
|
||||||
//break; // don't break to avoid changing behavior (for now)
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
int t = 0, tt;
|
int t = 0, tt;
|
||||||
@ -3209,7 +3202,7 @@ bool PRS1Import::ImportCompliance()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!ok) {
|
if (!ok || compliance->duration == 0) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
session->setSummaryOnly(true);
|
session->setSummaryOnly(true);
|
||||||
@ -3232,6 +3225,11 @@ bool PRS1DataChunk::ParseCompliance(void)
|
|||||||
if (this->family != 0 || this->familyVersion != 2) {
|
if (this->family != 0 || this->familyVersion != 2) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
// TODO: hardcoding this is ugly, think of a better approach
|
||||||
|
if (this->m_data.size() < 0x13) {
|
||||||
|
qWarning() << "compliance data too short:" << this->m_data.size();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
const unsigned char * data = (unsigned char *)this->m_data.constData();
|
const unsigned char * data = (unsigned char *)this->m_data.constData();
|
||||||
|
|
||||||
CHECK_VALUE(data[0x00], 0);
|
CHECK_VALUE(data[0x00], 0);
|
||||||
@ -4549,8 +4547,8 @@ PRS1DataChunk* PRS1DataChunk::ParseNext(QFile & f)
|
|||||||
// Make sure the calculated CRC over the entire chunk (header and data) matches the stored CRC.
|
// Make sure the calculated CRC over the entire chunk (header and data) matches the stored CRC.
|
||||||
if (chunk->calcCrc != chunk->storedCrc) {
|
if (chunk->calcCrc != chunk->storedCrc) {
|
||||||
// corrupt data block.. bleh..
|
// corrupt data block.. bleh..
|
||||||
qDebug() << chunk->m_path << "@" << chunk->m_filepos << "block CRC calc" << hex << chunk->calcCrc << "!= stored" << hex << chunk->storedCrc;
|
qWarning() << chunk->m_path << "@" << chunk->m_filepos << "block CRC calc" << hex << chunk->calcCrc << "!= stored" << hex << chunk->storedCrc;
|
||||||
//break; // don't break to avoid changing behavior (for now)
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Only return the chunk if it has passed all tests above.
|
// Only return the chunk if it has passed all tests above.
|
||||||
@ -4595,7 +4593,7 @@ bool PRS1DataChunk::ReadHeader(QFile & f)
|
|||||||
}
|
}
|
||||||
if (this->htype != PRS1_HTYPE_NORMAL && this->htype != PRS1_HTYPE_INTERVAL) {
|
if (this->htype != PRS1_HTYPE_NORMAL && this->htype != PRS1_HTYPE_INTERVAL) {
|
||||||
qWarning() << this->m_path << "unexpected htype:" << this->htype;
|
qWarning() << this->m_path << "unexpected htype:" << this->htype;
|
||||||
//break; // don't break to avoid changing behavior (for now)
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read format-specific variable-length header data.
|
// Read format-specific variable-length header data.
|
||||||
@ -4732,6 +4730,7 @@ bool PRS1DataChunk::ReadWaveformHeader(QFile & f)
|
|||||||
header = (unsigned char *)this->m_header.data();
|
header = (unsigned char *)this->m_header.data();
|
||||||
|
|
||||||
// Parse the variable-length waveform information.
|
// Parse the variable-length waveform information.
|
||||||
|
// TODO: move these checks into the parser, after the header checksum has been verified
|
||||||
int pos = 0x13;
|
int pos = 0x13;
|
||||||
for (int i = 0; i < wvfm_signals; ++i) {
|
for (int i = 0; i < wvfm_signals; ++i) {
|
||||||
quint8 kind = header[pos];
|
quint8 kind = header[pos];
|
||||||
|
@ -25,7 +25,7 @@
|
|||||||
//********************************************************************************************
|
//********************************************************************************************
|
||||||
// Please INCREMENT the following value when making changes to this loaders implementation
|
// Please INCREMENT the following value when making changes to this loaders implementation
|
||||||
// BEFORE making a release
|
// BEFORE making a release
|
||||||
const int prs1_data_version = 15;
|
const int prs1_data_version = 16;
|
||||||
//
|
//
|
||||||
//********************************************************************************************
|
//********************************************************************************************
|
||||||
#if 0 // Apparently unused
|
#if 0 // Apparently unused
|
||||||
|
@ -1,7 +1,8 @@
|
|||||||
/* SleepLib Session Header
|
/* SleepLib Session Header
|
||||||
*
|
*
|
||||||
* This stuff contains the session calculation smarts
|
* This stuff contains the session calculation smarts
|
||||||
*
|
*
|
||||||
|
* Copyright (c) 2019 The OSCAR Team
|
||||||
* Copyright (C) 2011-2018 Mark Watkins <mark@jedimark.net>
|
* Copyright (C) 2011-2018 Mark Watkins <mark@jedimark.net>
|
||||||
*
|
*
|
||||||
* This file is subject to the terms and conditions of the GNU General Public
|
* This file is subject to the terms and conditions of the GNU General Public
|
||||||
@ -169,7 +170,7 @@ class Session
|
|||||||
//! \brief Set last time to higher of 'd' and existing s_last. Throw warning if 'd' less than s_first.
|
//! \brief Set last time to higher of 'd' and existing s_last. Throw warning if 'd' less than s_first.
|
||||||
void set_last(qint64 d) {
|
void set_last(qint64 d) {
|
||||||
if (d <= s_first) {
|
if (d <= s_first) {
|
||||||
qWarning() << "Session::set_last() d<=s_first";
|
qWarning() << s_session << "Session::set_last() d<=s_first";
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -122,6 +122,7 @@ void PRS1Tests::testSessionsToYaml()
|
|||||||
|
|
||||||
static QString ts(qint64 msecs)
|
static QString ts(qint64 msecs)
|
||||||
{
|
{
|
||||||
|
// TODO: make this UTC so that tests don't vary by where they're run
|
||||||
return QDateTime::fromMSecsSinceEpoch(msecs).toString(Qt::ISODate);
|
return QDateTime::fromMSecsSinceEpoch(msecs).toString(Qt::ISODate);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
|
|
||||||
static QString ts(qint64 msecs)
|
static QString ts(qint64 msecs)
|
||||||
{
|
{
|
||||||
|
// TODO: make this UTC so that tests don't vary by where they're run
|
||||||
return QDateTime::fromMSecsSinceEpoch(msecs).toString(Qt::ISODate);
|
return QDateTime::fromMSecsSinceEpoch(msecs).toString(Qt::ISODate);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user