204 const std::vector<std::string> &suppressErrorsForMissingBranches)
206 fEntryList(entryList),
209 fWarnAboutLongerFriends(warnAboutLongerFriends),
210 fSuppressErrorsForMissingBranches(suppressErrorsForMissingBranches)
213 ::Error(
"TTreeReader::TTreeReader",
"TTree is NULL!");
235 : fEntryList(entryList), fNotify(this), fFriendProxies()
240 std::string msg =
"No TTree called ";
242 msg +=
" was found in the selected TDirectory.";
243 Error(
"TTreeReader",
"%s", msg.c_str());
253 for (std::deque<ROOT::Internal::TTreeReaderValueBase*>::const_iterator
255 (*i)->MarkTreeReaderUnavailable();
285 Error(
"Initialize",
"We are not processing a TChain but the TEntryList contains sublists. Please "
286 "provide a simple TEntryList with no sublists instead.");
292 fDirector = std::make_unique<ROOT::Internal::TBranchProxyDirector>(
fTree, -1);
338 "The current tree in the TChain %s has changed (e.g. by TTree::Process) "
339 "even though TTreeReader::SetEntry() was called, which switched the tree "
340 "again. Did you mean to call TTreeReader::SetLocalEntry()?",
350 "The TTree / TChain has an associated TEntryList. "
351 "TTreeReader ignores TEntryLists unless you construct the TTreeReader passing a TEntryList.");
357 Error(
"SetEntryBase()",
"There was an error while notifying the proxies.");
379 for (
size_t i = 0; i <
fValues.size(); ++i) {
386 const bool suppressErrorsForThisBranch =
400 if (suppressErrorsForThisBranch ||
430 if (
value->GetProxy())
458 const std::string mainTreeName =
462 if (!friendsList || friendsList->GetEntries() == 0)
474 const auto *frTree = fp->GetDirector()->GetTree();
484 auto *frTreeFromMain = frEl->
GetTree();
499 if (
fEntry >= frTreeFromMain->GetEntriesFast())
503 const std::string frTreeName =
dynamic_cast<const TChain *
>(frTree)
506 std::string msg =
"Last entry available from main tree '" + mainTreeName +
"' was " + std::to_string(
fEntry - 1) +
507 " but friend tree '" + frTreeName +
"' has more entries beyond the end of the main tree.";
508 Warning(
"SetEntryBase()",
"%s", msg.c_str());
541 Error(
"SetEntriesRange()",
"Start entry (%lld) must be lower than the available entries (%lld).", beginEntry,
547 if (endEntry > beginEntry)
554 if (beginEntry - 1 < 0)
562 Error(
"SetEntriesRange()",
"Error setting first entry %lld: %s",
577 tc->DropBranch(
"*",
true);
655 entryAfterList +=
static_cast<TChain *
>(
fTree)->GetTreeOffset()[treenum];
672 if (loadResult < 0) {
687 "There was an issue opening the last file associated to the TChain "
693 if (loadResult == -2) {
705 if (loadResult == -1) {
711 if (loadResult == -4) {
724 if (loadResult == -6) {
743 "Unexpected error '%lld' in %s::LoadTree", loadResult,
777 if (fp->GetReadEntry() >= 0)
781 const auto *frTree = fp->GetDirector()->GetTree();
784 const std::string frTreeName =
dynamic_cast<const TChain *
>(frTree)
789 if (!fp->HasIndex()) {
790 std::string msg =
"Cannot read entry " + std::to_string(entry) +
" from friend tree '" + frTreeName +
791 "'. The friend tree has less entries than the main tree. Make sure all trees "
792 "of the dataset have the same number of entries.";
793 throw std::runtime_error{msg};
848 TTree* tree =
nullptr;
861 Error(
"RegisterValueReader",
862 "Error registering reader for %s: TTreeReaderValue/Array objects must be created before the call to Next() / SetEntry() / SetLocalEntry(), or after TTreeReader::Restart()!",
875 std::deque<ROOT::Internal::TTreeReaderValueBase*>::iterator iReader
877 if (iReader ==
fValues.end()) {
#define R__ASSERT(e)
Checks condition e and reports a fatal error if it's false.
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void value
Base class of TTreeReaderValue.
@ kSetupMissingBranch
The specified branch cannot be found.
ESetupStatus GetSetupStatus() const
Return this TTreeReaderValue's setup status.
Detail::TBranchProxy * GetProxy() const
virtual const char * GetDerivedTypeName() const =0
TString fBranchName
Name of the branch to read data from.
const char * GetBranchName() const
virtual void CreateProxy()
Create the proxy object for our branch.
A chain is a collection of files containing TTree objects.
Describe directory structure in memory.
void GetObject(const char *namecycle, T *&ptr)
Get an object with proper type checking.
A List of entry numbers in a TTree or TChain.
virtual TList * GetLists() const
virtual Long64_t GetEntryAndTree(Long64_t index, Int_t &treenum)
Return the index of "index"-th non-zero entry in the TTree or TChain and the # of the corresponding t...
virtual Long64_t GetEntry(Long64_t index)
Return the number of the entry #index of this TEntryList in the TTree or TChain See also Next().
virtual Long64_t GetN() const
A TFriendElement TF describes a TTree object TF in a file.
virtual TTree * GetTree()
Return pointer to friend TTree.
const char * GetName() const override
Returns name of object.
void PrependLink(Chain &chain)
Set this link as the head of the chain's list of notify subscribers.
void RemoveLink(Chain &chain)
Remove this link from a chain's list of notify subscribers.
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
const char * Data() const
std::string_view View() const
A simple, robust and fast interface to read values from ROOT columnar datasets such as TTree,...
TTreeReader()
Default constructor. Call SetTree to connect to a TTree.
std::vector< std::string > fMissingProxies
ELoadTreeStatus fLoadTreeStatus
Indicator on how LoadTree was called 'last' time.
Long64_t GetEntries() const
Returns the number of entries of the TEntryList if one is provided, else of the TTree / TChain,...
EEntryStatus fEntryStatus
status of most recent read request
std::vector< std::string > fSuppressErrorsForMissingBranches
void SetTree(TTree *tree, TEntryList *entryList=nullptr)
Set (or update) the which tree to read from.
~TTreeReader() override
Tell all value readers that the tree reader does not exist anymore.
TNotifyLink< TTreeReader > fNotify
TTree and TChain will notify this object upon LoadTree, leading to a call to TTreeReader::Notify().
bool fProxiesSet
True if the proxies have been set, false otherwise.
@ kEntryNotFound
the tree entry number does not exist
@ kIndexedFriendNoMatch
A friend with TTreeIndex doesn't have an entry for this index.
@ kEntryUnknownError
LoadTree return less than -6, likely a 'newer' error code.
@ kEntryDictionaryError
problem reading dictionary info from tree
@ kMissingBranchWhenSwitchingTree
A branch was not found when switching to the next TTree in the chain.
@ kEntryBeyondEnd
last entry loop has reached its end
@ kEntryChainFileError
problem in opening a chain's file
@ kEntryNoTree
the tree does not exist
@ kEntryValid
data read okay
bool fSetEntryBaseCallingLoadTree
True if during the LoadTree execution triggered by SetEntryBase.
std::deque< ROOT::Internal::TTreeReaderValueBase * > fValues
readers that use our director
bool RegisterValueReader(ROOT::Internal::TTreeReaderValueBase *reader)
Add a value reader for this tree.
TTree * fTree
tree that's read
bool fWarnAboutLongerFriends
EEntryStatus SetEntriesRange(Long64_t beginEntry, Long64_t endEntry)
Set the range of entries to be loaded by Next(); end will not be loaded.
EEntryStatus SetEntryBase(Long64_t entry, bool local)
Load an entry into the tree, return the status of the read.
void WarnIfFriendsHaveMoreEntries()
@ kInternalLoadTree
Notify/LoadTree was last called from SetEntryBase.
@ kMissingBranchFromTree
Missing expected branch when loading new tree.
@ kNoTree
default state, no TTree is connected (formerly 'Zombie' state)
@ kExternalLoadTree
User code called LoadTree directly.
@ kLoadTreeNone
Notify has not been called yet.
void Initialize()
Initialization of the director.
void Restart()
Restart a Next() loop from entry 0 (of TEntryList index 0 of fEntryList is set).
TEntryList * fEntryList
entry list to be used
Long64_t fEntry
Current (non-local) entry of fTree or of fEntryList if set.
bool Notify() override
Notify director and values of a change in tree.
Long64_t fBeginEntry
This allows us to propagate the range to the TTreeCache.
void DeregisterValueReader(ROOT::Internal::TTreeReaderValueBase *reader)
Remove a value reader for this tree.
@ kBitIsExternalTree
we do not own the tree
@ kBitHaveWarnedAboutEntryListAttachedToTTree
the tree had a TEntryList and we have warned about that
@ kBitIsChain
our tree is a chain
bool SetProxies()
Tell readers we now have a tree.
ROOT::Internal::TFriendProxy & AddFriendProxy(std::size_t friendIdx)
std::vector< std::unique_ptr< ROOT::Internal::TFriendProxy > > fFriendProxies
Proxies to friend trees, created in TTreeReader[Value,Array]::CreateProxy.
std::unique_ptr< ROOT::Internal::TBranchProxyDirector > fDirector
proxying director
Long64_t fEndEntry
The end of the entry loop.
EEntryStatus SetEntry(Long64_t entry)
Set the next entry (or index of the TEntryList if that is set).
static constexpr const char *const fgEntryStatusText[kEntryUnknownError+1]
Long64_t GetCurrentEntry() const
Returns the index of the current entry being read.
A TTree represents a columnar dataset.
virtual Int_t StopCacheLearningPhase()
Stop the cache learning phase.
virtual Int_t AddBranchToCache(const char *bname, bool subbranches=false)
Add branch with name bname to the Tree cache.
TFile * GetCurrentFile() const
Return pointer to the current file.
TTreeCache * GetReadCache(TFile *file) const
Find and return the TTreeCache registered with the file and which may contain branches for us.
virtual TEntryList * GetEntryList()
Returns the entry list assigned to this tree.
virtual Long64_t GetEntries() const
virtual TTree * GetTree() const
virtual Long64_t LoadTree(Long64_t entry)
Set current entry.
virtual Long64_t GetEntriesFast() const
Return a number greater or equal to the total number of entries in the dataset.
TClass * IsA() const override
virtual Int_t SetCacheEntryRange(Long64_t first, Long64_t last)
interface to TTreeCache to set the cache entry range
virtual TList * GetListOfFriends() const
static constexpr Long64_t kMaxEntries
std::vector< std::string > GetTreeFullPaths(const TTree &tree)