#include "icsneo/disk/vsa/vsa02.h" using namespace icsneo; VSA02::VSA02(uint8_t* const recordBytes) : VSA() { setType(VSA::Type::AA02); constantIndex = *reinterpret_cast(recordBytes + 2); flags = *reinterpret_cast(recordBytes + 4); pieceCount = recordBytes[5]; timestamp = *reinterpret_cast(recordBytes + 6); samples.insert(samples.end(), recordBytes + 14, recordBytes + 30); checksum = *reinterpret_cast(recordBytes + 30); doChecksum(recordBytes); } void VSA02::doChecksum(uint8_t* recordBytes) { uint16_t* words = reinterpret_cast(recordBytes); uint16_t sum = 0; for(size_t i = 0; i < 15; i++) { sum += words[i]; } setChecksumFailed(sum != checksum); }