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 "OrderChecker.h"
|
|
|
|
|
2021-12-15 12:08:12 -05:00
|
|
|
namespace EventBuilder {
|
|
|
|
|
|
|
|
OrderChecker::OrderChecker()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
OrderChecker::~OrderChecker()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
bool OrderChecker::IsOrdered(const std::string& filename)
|
2021-12-13 12:28:56 -05:00
|
|
|
{
|
2021-12-15 12:08:12 -05:00
|
|
|
TFile* file = TFile::Open(filename.c_str(), "READ");
|
|
|
|
TTree* tree = (TTree*) file->Get("Data");
|
|
|
|
|
|
|
|
uint64_t ts;
|
|
|
|
tree->SetBranchAddress("Timestamp", &ts);
|
|
|
|
uint64_t prevStamp = 0;
|
|
|
|
|
|
|
|
for(Long64_t i=0; i<tree->GetEntries(); i++)
|
2021-12-13 12:28:56 -05:00
|
|
|
{
|
2021-12-15 12:08:12 -05:00
|
|
|
tree->GetEntry();
|
|
|
|
if(prevStamp >= ts)
|
|
|
|
{
|
2021-12-15 17:35:31 -05:00
|
|
|
EVB_WARN("Bad order at entry {0} out of {1}",i,tree->GetEntries());
|
2021-12-15 12:08:12 -05:00
|
|
|
return false;
|
|
|
|
}
|
2021-07-13 16:36:41 -04:00
|
|
|
}
|
2021-12-15 12:08:12 -05:00
|
|
|
|
|
|
|
file->Close();
|
|
|
|
return true;
|
2021-07-13 16:36:41 -04:00
|
|
|
}
|
|
|
|
|
2021-12-15 12:08:12 -05:00
|
|
|
}
|