Compare commits

...

1 Commits

Author SHA1 Message Date
Ryan@Home e54752cf5d update BinReader.h from NoHeader branch 2024-09-26 13:47:00 -04:00

View File

@ -94,6 +94,7 @@ class BinReader{
~BinReader();
void OpenFile(TString inFileName, int64_t timeOffset = 0, bool noHeader = false);
void SetCustomHeader(uint16_t Header);
// void SetDataFormat(bool has );
void CloseFile();
void UpdateFileSize();
@ -112,7 +113,7 @@ class BinReader{
void PrintStatus(int mod);
void SetTimeOffset(int64_t timeOffset) { this->timeOffset = timeOffset; }
};
//========================== implementation
@ -135,7 +136,7 @@ BinReader::BinReader(){
}
BinReader::~BinReader(){
fclose(inFile); /// fclose already delete inFile;
if( inFile ) fclose(inFile); /// fclose already delete inFile;
}
BinReader::BinReader(TString inFileName, int64_t timeOffset, bool noHeader){
@ -167,6 +168,11 @@ void BinReader::OpenFile(TString inFileName, int64_t timeOffset, bool noHeader){
gClock.Start("timer");
isOpened = true;
// normal format: isHeaderOK = true, isNoHeaderFormat= false, isOldFormat = false
// old format: isHeaderOK = true, isNoHeaderFormat= false, isOldFormat = true
//no header format: isHeaderOK = false, isNoHeaderFormat= true, isOldFormat = false
if( noHeader ){
data.Header = 0x0;
@ -202,12 +208,19 @@ void BinReader::OpenFile(TString inFileName, int64_t timeOffset, bool noHeader){
return ;
}
printf(" Header format. 0x%04x\n", data.Header);
isHeaderOK = true;
}
};
void BinReader::SetCustomHeader(uint16_t Header){
data.Header = Header;
isHeaderOK = true;
}
void BinReader::CloseFile(){
fclose(inFile);
if(inFile) fclose(inFile);
inFile = nullptr;
isOpened = false;
data.Clear();
inFileSize = 0;
@ -226,6 +239,7 @@ void BinReader::UpdateFileSize(){
bool BinReader::IsEndOfFile() {
if( endOfFile ) return true;
if( inFile == nullptr ) return true;
return feof(inFile) > 0 ? true: false;
}
@ -244,8 +258,7 @@ int BinReader::ReadBlock(int skipTrace){
if( feof(inFile) ) return -1;
if( endOfFile ) return -1;
if( isNoHeaderFormat ) {
if( isNoHeaderFormat && data.Header == 0x0 ) {
FillData(&data.BoardID);
FillData(&data.Channel);
FillData(&data.TimeStamp);
@ -331,7 +344,7 @@ void BinReader::ScanNumHit(){
printf("scan complete: number of data Block : %ld\n", numHit);
rewind(inFile); ///back to the File begining
if( !isOldFormat && isHeaderOK ){
if( isOldFormat == false && isNoHeaderFormat == false ){ // only when normal format
FillData(&data.Header);
}
inFilePos = 0;
@ -364,5 +377,4 @@ void BinReader::PrintStatus(int mod){
}
#endif