11#ifndef ROOT_RDF_RTREECOLUMNREADER
12#define ROOT_RDF_RTREECOLUMNREADER
70 bool fCopyWarningPrinted =
false;
74 auto &readerArray = *fTreeArray;
79 const auto readerArraySize = readerArray.GetSize();
80 if (EStorageType::kUnknown == fStorageType && readerArraySize > 1) {
82 fStorageType = EStorageType::kContiguous;
83 for (
auto i = 0u; i < readerArraySize - 1; ++i) {
84 if ((
char *)&readerArray[i + 1] - (
char *)&readerArray[i] !=
sizeof(T)) {
85 fStorageType = EStorageType::kSparse;
91 if (EStorageType::kContiguous == fStorageType ||
92 (EStorageType::kUnknown == fStorageType && readerArray.GetSize() < 2)) {
93 if (readerArraySize > 0) {
97 auto readerArrayAddr = &readerArray.At(0);
98 RVec<T> rvec(readerArrayAddr, readerArraySize);
99 std::swap(fRVec, rvec);
102 std::swap(fRVec, emptyVec);
107 if (!fCopyWarningPrinted) {
108 Warning(
"RTreeColumnReader::Get",
109 "Branch %s hangs from a non-split branch. A copy is being performed in order "
110 "to properly read the content.",
111 readerArray.GetBranchName());
112 fCopyWarningPrinted =
true;
115 (
void)fCopyWarningPrinted;
117 if (readerArraySize > 0) {
118 RVec<T> rvec(readerArray.begin(), readerArray.end());
119 std::swap(fRVec, rvec);
122 std::swap(fRVec, emptyVec);
156 auto &readerArray = *fTreeArray;
157 const auto readerArraySize = readerArray.GetSize();
158 if (readerArraySize > 0) {
160 RVec<bool> rvec(readerArray.begin(), readerArray.end());
161 std::swap(fRVec, rvec);
164 std::swap(fRVec, emptyVec);
typedef void(GLAPIENTRYP _GLUfuncptr)(void)
void Warning(const char *location, const char *msgfmt,...)
Use this function in warning situations.
std::unique_ptr< TTreeReaderArray< T > > fTreeArray
RTreeColumnReader(TTreeReader &r, const std::string &colName)
EStorageType
Enumerator for the memory layout of the branch.
~RTreeColumnReader()
See the other class template specializations for an explanation.
RVec< T > fRVec
We return a reference to this RVec to clients, to guarantee a stable address and contiguous memory la...
void * GetImpl(Long64_t) final
RVec< bool > fRVec
We return a reference to this RVec to clients, to guarantee a stable address and contiguous memory la...
~RTreeColumnReader()
See the other class template specializations for an explanation.
std::unique_ptr< TTreeReaderArray< bool > > fTreeArray
RTreeColumnReader(TTreeReader &r, const std::string &colName)
void * GetImpl(Long64_t) final
RTreeColumnReader specialization for TTree values read via TTreeReaderValues.
RTreeColumnReader(TTreeReader &r, const std::string &colName)
Construct the RTreeColumnReader. Actual initialization is performed lazily by the Init method.
~RTreeColumnReader()
The dtor resets the TTreeReaderValue object.
void * GetImpl(Long64_t) final
std::unique_ptr< TTreeReaderValue< T > > fTreeValue
A "std::vector"-like collection of values implementing handy operation to analyse them.
An interface for reading collections stored in ROOT columnar datasets.
An interface for reading values stored in ROOT columnar datasets.
A simple, robust and fast interface to read values from ROOT columnar datasets such as TTree,...
tbb::task_arena is an alias of tbb::interface7::task_arena, which doesn't allow to forward declare tb...