204 : fTree(tree), fEntryList(entryList), fNotify(this), fWarnAboutLongerFriends(warnAboutLongerFriends)
207 ::Error(
"TTreeReader::TTreeReader",
"TTree is NULL!");
229 fEntryList(entryList),
235 std::string msg =
"No TTree called ";
237 msg +=
" was found in the selected TDirectory.";
238 Error(
"TTreeReader",
"%s", msg.c_str());
248 for (std::deque<ROOT::Internal::TTreeReaderValueBase*>::const_iterator
250 (*i)->MarkTreeReaderUnavailable();
280 Error(
"Initialize",
"We are not processing a TChain but the TEntryList contains sublists. Please "
281 "provide a simple TEntryList with no sublists instead.");
287 fDirector = std::make_unique<ROOT::Internal::TBranchProxyDirector>(
fTree, -1);
315 "The current tree in the TChain %s has changed (e.g. by TTree::Process) "
316 "even though TTreeReader::SetEntry() was called, which switched the tree "
317 "again. Did you mean to call TTreeReader::SetLocalEntry()?",
327 "The TTree / TChain has an associated TEntryList. "
328 "TTreeReader ignores TEntryLists unless you construct the TTreeReader passing a TEntryList.");
333 Error(
"SetEntryBase()",
"There was an error while notifying the proxies.");
353 for (
size_t i = 0; i <
fValues.size(); ++i) {
406 const std::string mainTreeName =
410 if (!friendsList || friendsList->GetEntries() == 0)
420 const auto *frTree = fp->GetDirector()->GetTree();
430 auto *frTreeFromMain = frEl->
GetTree();
445 if (
fEntry >= frTreeFromMain->GetEntriesFast())
449 const std::string frTreeName =
dynamic_cast<const TChain *
>(frTree)
452 std::string msg =
"Last entry available from main tree '" + mainTreeName +
"' was " + std::to_string(
fEntry - 1) +
453 " but friend tree '" + frTreeName +
"' has more entries beyond the end of the main tree.";
454 Warning(
"SetEntryBase()",
"%s", msg.c_str());
487 Error(
"SetEntriesRange()",
"Start entry (%lld) must be lower than the available entries (%lld).", beginEntry,
493 if (endEntry > beginEntry)
500 if (beginEntry - 1 < 0)
508 Error(
"SetEntriesRange()",
"Error setting first entry %lld: %s",
523 tc->DropBranch(
"*",
true);
601 entryAfterList +=
static_cast<TChain *
>(
fTree)->GetTreeOffset()[treenum];
618 if (loadResult < 0) {
633 "There was an issue opening the last file associated to the TChain "
639 if (loadResult == -2) {
651 if (loadResult == -1) {
657 if (loadResult == -4) {
671 "Unexpected error '%lld' in %s::LoadTree", loadResult,
694 if (fp->GetReadEntry() >= 0)
698 const auto *frTree = fp->GetDirector()->GetTree();
701 const std::string frTreeName =
dynamic_cast<const TChain *
>(frTree)
706 if (!fp->HasIndex()) {
707 std::string msg =
"Cannot read entry " + std::to_string(entry) +
" from friend tree '" + frTreeName +
708 "'. The friend tree has less entries than the main tree. Make sure all trees "
709 "of the dataset have the same number of entries.";
710 throw std::runtime_error{msg};
764 TTree* tree =
nullptr;
777 Error(
"RegisterValueReader",
778 "Error registering reader for %s: TTreeReaderValue/Array objects must be created before the call to Next() / SetEntry() / SetLocalEntry(), or after TTreeReader::Restart()!",
791 std::deque<ROOT::Internal::TTreeReaderValueBase*>::iterator iReader
793 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.
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
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.
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
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
@ kEntryUnknownError
LoadTree return less than -4, likely a 'newer' error code.
@ kEntryDictionaryError
problem reading dictionary info from tree
@ 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
std::deque< std::unique_ptr< ROOT::Internal::TFriendProxy > > fFriendProxies
proxying for friend TTrees
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.
@ 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.
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
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)