SPS_SABRE_EventBuilder/src/evb/OrderChecker.cpp

41 lines
822 B
C++
Raw Normal View History

2021-07-13 16:36:41 -04:00
/*
OrderChecker.cpp
Very simple class designed to test whether or not a root file is time ordered.
Meant to be used with newly converted from binary data. Only for development.
Written by G.W. McCann Oct. 2020
*/
#include "EventBuilder.h"
#include "OrderChecker.h"
OrderChecker::OrderChecker()
{
2021-07-13 16:36:41 -04:00
}
OrderChecker::~OrderChecker()
{
2021-07-13 16:36:41 -04:00
}
bool OrderChecker::IsOrdered(const std::string& filename)
{
2021-07-13 16:36:41 -04:00
TFile* file = TFile::Open(filename.c_str(), "READ");
TTree* tree = (TTree*) file->Get("Data");
uint64_t ts;
2021-07-13 16:36:41 -04:00
tree->SetBranchAddress("Timestamp", &ts);
uint64_t prevStamp = 0;
2021-07-13 16:36:41 -04:00
for(Long64_t i=0; i<tree->GetEntries(); i++)
{
2021-07-13 16:36:41 -04:00
tree->GetEntry();
if(prevStamp >= ts)
{
2021-07-13 16:36:41 -04:00
std::cerr<<"Bad order at entry "<<i<<" out of "<<tree->GetEntries()<<std::endl;
return false;
}
}
file->Close();
return true;
}