50#include <unordered_set>
72 " cannot be constructed from a class that's not at least Interpreted"));
78 if (
field.GetTypeName() ==
"TObject") {
83 "use RProxiedCollectionField instead"));
94 R__FAIL(
field.GetTypeName() +
" has streamer mode enforced, not supported as native RNTuple class"));
106 " with a custom streamer; not supported natively in RNTuple"));
132 for (
size_t i = 0; i <
itemFields.size(); ++i) {
176 for (
int i : {0, 1}) {
196 fSubfieldsInfo(
source.fSubfieldsInfo)
198 for (
const auto &
f :
source.GetConstSubfields()) {
235 " virtually inherits from " +
baseClass->GetName()));
258 std::string typeName{
dataMember->GetTrueTypeName()};
262 for (
int dim = 0,
n =
dataMember->GetArrayDim(); dim <
n; ++dim) {
263 typeName +=
"[" + std::to_string(
dataMember->GetMaxIndex(dim)) +
"]";
278 for (
const auto &[
_,
si] : fStagingItems) {
279 if (!(
si.fField->GetTraits() & kTraitTriviallyDestructible)) {
280 auto deleter = GetDeleterOf(*
si.fField);
281 deleter->operator()(fStagingArea.get() +
si.fOffset,
true );
289 fSubfieldsInfo.push_back(
info);
320 std::size_t
nskip = 0;
327 <<
"ignoring I/O customization rule with unsupported type: " <<
rule->GetRuleType();
338 <<
"ignoring I/O customization rule due to conflicting source member type: " <<
itrSrc->second <<
" vs. "
350 if (
rule->GetTarget() ==
nullptr) {
371 for (
unsigned i = 0; i < fSubfields.size(); i++) {
372 nbytes += CallAppendOn(*fSubfields[i],
static_cast<const unsigned char *
>(from) + fSubfieldsInfo[i].fOffset);
379 for (
const auto &[
_,
si] : fStagingItems) {
382 for (
unsigned i = 0; i < fSubfields.size(); i++) {
383 CallReadOn(*fSubfields[i],
globalIndex,
static_cast<unsigned char *
>(to) + fSubfieldsInfo[i].fOffset);
389 for (
const auto &[
_,
si] : fStagingItems) {
390 CallReadOn(*
si.fField,
localIndex, fStagingArea.get() +
si.fOffset);
392 for (
unsigned i = 0; i < fSubfields.size(); i++) {
393 CallReadOn(*fSubfields[i],
localIndex,
static_cast<unsigned char *
>(to) + fSubfieldsInfo[i].fOffset);
419 if (
classVersion != GetTypeVersion() || className != GetTypeName()) {
421 if (!fStagingClass) {
448 throw RException(
R__FAIL(std::string(
"cannot find on disk rule source member ") + GetTypeName() +
"." +
455 auto fieldZero = std::make_unique<RFieldZero>();
473 for (
const auto &[
_,
si] : fStagingItems) {
475 if (!(
memberField.GetTraits() & kTraitTriviallyConstructible)) {
476 CallConstructValueOn(
memberField, fStagingArea.get() +
si.fOffset);
484 auto func =
rule->GetReadFunctionPointer();
485 if (func ==
nullptr) {
490 TVirtualObject onfileObj{nullptr};
500 std::vector<const TSchemaRule *>
rules;
510 rules = FindRules(
nullptr);
512 SetStagingClass(GetTypeName(), GetTypeVersion());
521 auto substitute = std::make_unique<RStreamerField>(GetFieldName(), GetTypeName());
543 throw RException(
R__FAIL(
"incompatible type name for field " + GetFieldName() +
": " + GetTypeName() +
549 return r->GetSource() && (r->GetSource()->GetEntries() > 0);
557 for (
auto &[
_,
si] : fStagingItems) {
565 if (!
rule->GetTarget())
575 AddReadCallbacksFromIORule(
rule);
580 for (
auto &
field : fSubfields) {
583 CallSetArtificialOn(*
field);
590 throw RException(
R__FAIL(std::string(
"incompatible number of base classes for field ") + GetFieldName() +
": " +
592 " base classes in memory "
603 EnsureMatchingOnDiskField(desc, kDiffTypeVersion | kDiffTypeName).ThrowOnError();
621 std::vector<RValue>
result;
625 for (
unsigned i = 0; i <
fSubfields.size(); i++) {
665 visitor.VisitClassField(*
this);
672 fSoAClass(
source.fSoAClass),
673 fSoAMemberOffsets(
source.fSoAMemberOffsets)
694 static std::once_flag
once;
695 std::call_once(
once, []() {
703 " is not marked with the rntupleSoARecord "
704 "dictionary option; cannot create corresponding RSoAField."));
713 throw RException(
R__FAIL(std::string(
"version mismatch between SoA type and underlying record type: ") +
715 std::to_string(
fSubfields[0]->GetTypeVersion())));
724 assert(!
f->GetFieldName().empty());
725 if (
f->GetFieldName()[0] ==
':') {
726 throw RException(
R__FAIL(
"SoA fields with inheritance are currently unsupported"));
737 " virtually inherits from " +
baseClass->GetName()));
740 throw RException(
R__FAIL(
"SoA fields with inheritance are currently unsupported"));
753 const std::string typeName{
dataMember->GetTrueTypeName()};
822 const std::size_t
nSoAMembers = fSoAMemberOffsets.size();
826 const void *
rvecPtr =
static_cast<const unsigned char *
>(from) + fSoAMemberOffsets[i];
832 if (
static_cast<std::size_t
>(*
sizePtr) !=
N) {
833 const auto f = fRecordMemberFields[i];
835 " vs. " + std::to_string(
N) +
" (expected)"));
843 const void *
rvecPtr =
static_cast<const unsigned char *
>(from) + fSoAMemberOffsets[i];
847 GetPrincipalColumnOf(*memberField)->AppendV(*
beginPtr,
N);
848 nbytes +=
N * GetPrincipalColumnOf(*memberField)->GetElement()->GetPackedSize();
850 for (std::size_t
j = 0;
j <
N; ++
j) {
858 fPrincipalColumn->Append(&fNWritten);
859 return nbytes + fPrincipalColumn->GetElement()->GetPackedSize();
873 void *
rvecPtr =
static_cast<unsigned char *
>(to) + fSoAMemberOffsets[i];
879 for (std::size_t
j = 0;
j <
N; ++
j) {
888 fSoAClass->New(
where);
908 fSplitFields = std::make_unique<std::vector<std::unique_ptr<ROOT::RRVecField>>>();
919 std::vector<RValue> values;
981 switch (
enump->GetUnderlyingType()) {
1000 std::unique_ptr<RFieldBase>
intField)
1009 auto newIntField = fSubfields[0]->Clone(fSubfields[0]->GetFieldName());
1016 EnsureMatchingOnDiskField(desc, kDiffTypeName | kDiffTypeVersion).ThrowOnError();
1021 std::vector<RValue>
result;
1022 result.emplace_back(fSubfields[0]->BindValue(
value.GetPtr<
void>()));
1028 visitor.VisitEnumField(*
this);
1061 std::array<std::unique_ptr<RFieldBase>, 2>
itemClones = {fSubfields[0]->Clone(fSubfields[0]->GetFieldName()),
1062 fSubfields[1]->Clone(fSubfields[1]->GetFieldName())};
1068 static const std::vector<std::string>
prefixes = {
"std::pair<",
"std::tuple<"};
1070 EnsureMatchingOnDiskField(desc, kDiffTypeName).ThrowOnError();
1071 EnsureMatchingTypePrefix(desc,
prefixes).ThrowOnError();
1093 (
ifuncs.fNext !=
nullptr));
1102 if (!
classp->GetCollectionProxy())
1106 "std::set<",
"std::unordered_set<",
"std::multiset<",
"std::unordered_multiset<",
1107 "std::map<",
"std::unordered_map<",
"std::multimap<",
"std::unordered_multimap<"};
1123 fProxy.reset(
classp->GetCollectionProxy()->Generate());
1126 if (
fProxy->HasPointers())
1127 throw RException(
R__FAIL(
"collection proxies whose value type is a pointer are not supported"));
1138 throw RException(
R__FAIL(
"custom associative collection proxies not supported"));
1140 std::unique_ptr<ROOT::RFieldBase>
itemField;
1146 switch (
fProxy->GetType()) {
1172 clone->fItemSize = fItemSize;
1173 clone->Attach(fSubfields[0]->Clone(fSubfields[0]->GetFieldName()));
1183 (fCollectionType ==
kSTLvector ? fItemSize : 0U)}) {
1184 nbytes += CallAppendOn(*fSubfields[0], ptr);
1189 fPrincipalColumn->Append(&fNWritten);
1190 return nbytes + fPrincipalColumn->GetElement()->GetPackedSize();
1205 (fCollectionType ==
kSTLvector || obj != to ? fItemSize : 0U)}) {
1209 fProxy->Commit(obj);
1234 EnsureMatchingOnDiskCollection(desc).ThrowOnError();
1246 return std::make_unique<RProxiedCollectionDeleter>(fProxy, GetDeleterOf(*fSubfields[0]),
itemSize);
1248 return std::make_unique<RProxiedCollectionDeleter>(fProxy);
1252 std::shared_ptr<TVirtualCollectionProxy>
proxy)
1259 :
RDeleter(
proxy->GetCollectionClass()->GetClassAlignment()),
1272 fItemDeleter->operator()(ptr,
true );
1281 std::vector<RValue>
result;
1298 const auto align =
fProxy->GetCollectionClass()->GetClassAlignment();
1305 visitor.VisitProxiedCollectionField(*
this);
1326 return std::make_unique<RMapField>(
newName, fMapType, fSubfields[0]->Clone(fSubfields[0]->GetFieldName()));
1331 static const std::vector<std::string>
prefixesRegular = {
"std::map<",
"std::unordered_map<"};
1333 EnsureMatchingOnDiskCollection(desc).ThrowOnError();
1336 case EMapType::kMap:
1337 case EMapType::kUnorderedMap: EnsureMatchingTypePrefix(desc,
prefixesRegular).ThrowOnError();
break;
1361 return std::make_unique<RSetField>(
newName, fSetType, fSubfields[0]->Clone(fSubfields[0]->GetFieldName()));
1366 static const std::vector<std::string>
prefixesRegular = {
"std::set<",
"std::unordered_set<",
"std::map<",
1367 "std::unordered_map<"};
1369 EnsureMatchingOnDiskCollection(desc).ThrowOnError();
1372 case ESetType::kSet:
1373 case ESetType::kUnorderedSet: EnsureMatchingTypePrefix(desc,
prefixesRegular).ThrowOnError();
break;
1390 RCallbackStreamerInfo fCallbackStreamerInfo;
1436 fClass->Streamer(
const_cast<void *
>(from), buffer);
1438 auto nbytes = buffer.Length();
1439 fAuxiliaryColumn->AppendV(buffer.Buffer(), buffer.Length());
1441 fPrincipalColumn->Append(&fIndex);
1442 return nbytes + fPrincipalColumn->GetElement()->GetPackedSize();
1453 fClass->Streamer(to, buffer);
1478 source.RegisterStreamerInfos();
1484 EnsureMatchingOnDiskField(desc, kDiffTypeName | kDiffTypeVersion).ThrowOnError();
1537 visitor.VisitStreamerField(*
this);
1554 Attach(
source.GetConstSubfields()[0]->Clone(
"fUniqueID"));
1577 auto *obj =
static_cast<const TObject *
>(from);
1583 nbytes += CallAppendOn(*fSubfields[0],
reinterpret_cast<const unsigned char *
>(from) + GetOffsetUniqueID());
1585 UInt_t bits = *
reinterpret_cast<const UInt_t *
>(
reinterpret_cast<const unsigned char *
>(from) + GetOffsetBits());
1587 nbytes += CallAppendOn(*fSubfields[1], &bits);
1596 auto *obj =
static_cast<TObject *
>(to);
1601 *
reinterpret_cast<UInt_t *
>(
reinterpret_cast<unsigned char *
>(to) + GetOffsetUniqueID()) =
uniqueID;
1605 *
reinterpret_cast<UInt_t *
>(
reinterpret_cast<unsigned char *
>(to) + GetOffsetBits()) = bits;
1620 CallReadOn(*fSubfields[1],
localIndex, &bits);
1641 std::vector<RValue>
result;
1644 auto charPtr =
static_cast<unsigned char *
>(ptr.get());
1645 result.emplace_back(fSubfields[0]->BindValue(std::shared_ptr<void>(ptr,
charPtr + GetOffsetUniqueID())));
1646 result.emplace_back(fSubfields[1]->BindValue(std::shared_ptr<void>(ptr,
charPtr + GetOffsetBits())));
1662 visitor.VisitTObjectField(*
this);
1686 for (
unsigned i = 0; i <
fSubfields.size(); ++i) {
1687 std::string
memberName(
"_" + std::to_string(i));
1697 std::vector<std::unique_ptr<RFieldBase>>
itemClones;
1699 for (
const auto &
f : fSubfields) {
1707 static const std::vector<std::string>
prefixes = {
"std::pair<",
"std::tuple<"};
1709 EnsureMatchingOnDiskField(desc, kDiffTypeName).ThrowOnError();
1710 EnsureMatchingTypePrefix(desc,
prefixes).ThrowOnError();
1730 std::variant<char> t;
1731 constexpr auto sizeOfT =
sizeof(t);
1733 static_assert(
sizeOfT == 2 ||
sizeOfT == 8,
"unsupported std::variant layout");
1737template <std::
size_t VariantSizeT>
1739 using ValueType_t =
typename std::conditional_t<
VariantSizeT == 1, std::uint8_t,
1740 typename std::conditional_t<VariantSizeT == 4, std::uint32_t, void>>;
1747 fMaxItemSize(
source.fMaxItemSize),
1748 fMaxAlignment(
source.fMaxAlignment),
1749 fTagOffset(
source.fTagOffset),
1750 fVariantOffset(
source.fVariantOffset),
1753 for (
const auto &
f :
source.GetConstSubfields())
1754 Attach(
f->Clone(
f->GetFieldName()));
1774 for (
unsigned int i = 0; i <
nFields; ++i) {
1803 return (tag ==
TagType_t(-1)) ? 0 : tag + 1;
1815 auto tag = GetTag(from, fTagOffset);
1819 nbytes += CallAppendOn(*fSubfields[tag - 1],
reinterpret_cast<const unsigned char *
>(from) + fVariantOffset);
1820 index = fNWritten[tag - 1]++;
1838 void *
varPtr =
reinterpret_cast<unsigned char *
>(to) + fVariantOffset;
1839 CallConstructValueOn(*fSubfields[tag - 1],
varPtr);
1842 SetTag(to, fTagOffset, tag);
1863 static const std::vector<std::string>
prefixes = {
"std::variant<"};
1865 EnsureMatchingOnDiskField(desc, kDiffTypeName).ThrowOnError();
1866 EnsureMatchingTypePrefix(desc,
prefixes).ThrowOnError();
1869 if (fSubfields.size() !=
fieldDesc.GetLinkIds().size()) {
1870 throw RException(
R__FAIL(
"number of variants on-disk do not match for " + GetQualifiedFieldName() +
"\n" +
1878 CallConstructValueOn(*fSubfields[0],
reinterpret_cast<unsigned char *
>(
where) + fVariantOffset);
1879 SetTag(
where, fTagOffset, 1);
1884 auto tag = GetTag(
objPtr, fTagOffset);
1886 fItemDeleters[tag - 1]->operator()(
reinterpret_cast<unsigned char *
>(
objPtr) + fVariantOffset,
true );
1895 for (
const auto &
f : fSubfields) {
1898 return std::make_unique<RVariantDeleter>(fTagOffset, fVariantOffset, GetAlignment(), std::move(
itemDeleters));
1903 return std::max(fMaxAlignment,
alignof(RVariantTag<
GetVariantTagSize()>::ValueType_t));
1916 std::fill(fNWritten.begin(), fNWritten.end(), 0);
#define R__FAIL(msg)
Short-hand to return an RResult<T> in an error state; the RError is implicitly converted into RResult...
#define R__LOG_WARNING(...)
size_t size(const MatrixT &matrix)
retrieve the size of a square matrix
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
#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 char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h Atom_t Int_t ULong_t ULong_t unsigned char prop_list Atom_t Atom_t target
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t r
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t result
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t index
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t child
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void value
Option_t Option_t TPoint TPoint const char mode
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h Atom_t Int_t ULong_t ULong_t unsigned char prop_list Atom_t Atom_t Atom_t Time_t type
Abstract base class for classes implementing the visitor design pattern.
void operator()(void *objPtr, bool dtorOnly) final
The SoA field provides I/O for an in-memory SoA layout linked to an on-disk collection of the underly...
void ConstructValue(void *where) const final
Constructs value in a given location of size at least GetValueSize(). Called by the base class' Creat...
void ReadGlobalImpl(ROOT::NTupleSize_t globalIndex, void *to) final
std::vector< std::size_t > fSoAMemberOffsets
The offset of the RVec members in the SoA type in the order of subfields of the underlying record typ...
void AcceptVisitor(ROOT::Detail::RFieldVisitor &visitor) const final
const std::type_info * GetPolymorphicTypeInfo() const
For polymorphic classes (that declare or inherit at least one virtual method), return the expected dy...
size_t GetValueSize() const final
What sizeof(T) for this type returns.
std::vector< std::unique_ptr< RDeleter > > fRecordMemberDeleters
std::vector< RValue > SplitValue(const RValue &value) const final
Creates the list of direct child values given an existing value for this field.
size_t GetAlignment() const final
What alignof(T) for this type returns.
std::vector< RFieldBase * > fRecordMemberFields
Direct access to the member fields of the underlying record.
RSoAField(std::string_view fieldName, const RSoAField &source)
Used by CloneImpl.
std::uint32_t GetTypeVersion() const final
Indicates an evolution of the C++ type itself.
std::uint32_t GetTypeChecksum() const final
Return the current TClass reported checksum of this class. Only valid if kTraitTypeChecksum is set.
const RColumnRepresentations & GetColumnRepresentations() const final
Implementations in derived classes should return a static RColumnRepresentations object.
std::size_t AppendImpl(const void *from) final
Operations on values of complex types, e.g.
std::unique_ptr< RFieldBase > CloneImpl(std::string_view newName) const final
Called by Clone(), which additionally copies the on-disk ID.
void GenerateColumns() final
Implementations in derived classes should create the backing columns corresponding to the field type ...
std::unique_ptr< std::vector< std::unique_ptr< ROOT::RRVecField > > > fSplitFields
For reading and writing, the RVecs of the SoA class do not have a dedicated field.
std::unique_ptr< std::mutex > fLockSplitFields
protects the fSplitFields member.
Holds the index and the tag of a kSwitch column.
static std::string SerializeStreamerInfos(const StreamerInfoMap_t &infos)
Abstract interface to read data from an ntuple.
void operator()(void *objPtr, bool dtorOnly) final
RClassDeleter(TClass *cl)
The field for a class with dictionary.
std::unique_ptr< RFieldBase > BeforeConnectPageSource(ROOT::Internal::RPageSource &pageSource) final
Called by ConnectPageSource() before connecting; derived classes may override this as appropriate,...
void AddReadCallbacksFromIORule(const TSchemaRule *rule)
Register post-read callback corresponding to a ROOT I/O customization rules.
std::size_t AppendImpl(const void *from) final
Operations on values of complex types, e.g.
std::unique_ptr< RFieldBase > CloneImpl(std::string_view newName) const final
Called by Clone(), which additionally copies the on-disk ID.
std::size_t GetAlignment() const final
What alignof(T) for this type returns.
void ReconcileOnDiskField(const RNTupleDescriptor &desc) final
For non-artificial fields, check compatibility of the in-memory field and the on-disk field.
std::vector< RSubfieldInfo > fSubfieldsInfo
Additional information kept for each entry in fSubfields
void Attach(std::unique_ptr< RFieldBase > child, RSubfieldInfo info)
std::size_t GetValueSize() const final
What sizeof(T) for this type returns.
void ReadGlobalImpl(ROOT::NTupleSize_t globalIndex, void *to) final
void ConstructValue(void *where) const final
Constructs value in a given location of size at least GetValueSize(). Called by the base class' Creat...
void AcceptVisitor(ROOT::Detail::RFieldVisitor &visitor) const final
std::vector< const TSchemaRule * > FindRules(const ROOT::RFieldDescriptor *fieldDesc)
Given the on-disk information from the page source, find all the I/O customization rules that apply t...
ROOT::DescriptorId_t LookupMember(const ROOT::RNTupleDescriptor &desc, std::string_view memberName, ROOT::DescriptorId_t classFieldId)
Returns the id of member 'name' in the class field given by 'fieldId', or kInvalidDescriptorId if no ...
void ReadInClusterImpl(RNTupleLocalIndex localIndex, void *to) final
std::uint32_t GetTypeVersion() const final
Indicates an evolution of the C++ type itself.
RClassField(std::string_view fieldName, const RClassField &source)
Used by CloneImpl.
void PrepareStagingArea(const std::vector< const TSchemaRule * > &rules, const ROOT::RNTupleDescriptor &desc, const ROOT::RFieldDescriptor &classFieldId)
If there are rules with inputs (source members), create the staging area according to the TClass inst...
std::vector< RValue > SplitValue(const RValue &value) const final
Creates the list of direct child values given an existing value for this field.
const std::type_info * GetPolymorphicTypeInfo() const
For polymorphic classes (that declare or inherit at least one virtual method), return the expected dy...
std::uint32_t GetTypeChecksum() const final
Return the current TClass reported checksum of this class. Only valid if kTraitTypeChecksum is set.
static constexpr const char * kPrefixInherited
Prefix used in the subfield names generated for base classes.
void SetStagingClass(const std::string &className, unsigned int classVersion)
Sets fStagingClass according to the given name and version.
The field for an unscoped or scoped enum with dictionary.
std::unique_ptr< RFieldBase > CloneImpl(std::string_view newName) const final
Called by Clone(), which additionally copies the on-disk ID.
std::vector< RValue > SplitValue(const RValue &value) const final
Creates the list of direct child values given an existing value for this field.
void AcceptVisitor(ROOT::Detail::RFieldVisitor &visitor) const final
REnumField(std::string_view fieldName, TEnum *enump)
void ReconcileOnDiskField(const RNTupleDescriptor &desc) final
For non-artificial fields, check compatibility of the in-memory field and the on-disk field.
Base class for all ROOT issued exceptions.
The list of column representations a field can have.
A functor to release the memory acquired by CreateValue() (memory and constructor).
Points to an object with RNTuple I/O support and keeps a pointer to the corresponding field.
A field translates read and write calls from/to underlying columns to/from tree values.
void Attach(std::unique_ptr< RFieldBase > child, std::string_view expectedChildName="")
Add a new subfield to the list of nested fields.
std::vector< std::unique_ptr< RFieldBase > > fSubfields
Collections and classes own subfields.
static std::unique_ptr< RDeleter > GetDeleterOf(const RFieldBase &other)
std::uint32_t fTraits
Properties of the type that allow for optimizations of collections of that type.
@ kTraitTriviallyDestructible
The type is cleaned up just by freeing its memory. I.e. the destructor performs a no-op.
@ kTraitTriviallyConstructible
No constructor needs to be called, i.e.
@ kTraitSoACollection
The field represents a collection in SoA layout.
@ kTraitTypeChecksum
The TClass checksum is set and valid.
static RResult< std::unique_ptr< RFieldBase > > Create(const std::string &fieldName, const std::string &typeName, const ROOT::RCreateFieldOptions &options, const ROOT::RNTupleDescriptor *desc, ROOT::DescriptorId_t fieldId)
Factory method to resurrect a field from the stored on-disk type information.
std::string fTypeAlias
A typedef or using name that was used when creating the field.
const std::string & GetTypeName() const
RValue BindValue(std::shared_ptr< void > objPtr)
Creates a value from a memory location with an already constructed object.
Metadata stored for every field of an RNTuple.
The container field for an ntuple model, which itself has no physical representation.
std::vector< std::unique_ptr< RFieldBase > > ReleaseSubfields()
Moves all subfields into the returned vector.
Classes with dictionaries that can be inspected by TClass.
RField(std::string_view name)
RMapField(std::string_view fieldName, EMapType mapType, std::unique_ptr< RFieldBase > itemField)
void ReconcileOnDiskField(const RNTupleDescriptor &desc) final
For non-artificial fields, check compatibility of the in-memory field and the on-disk field.
std::unique_ptr< RFieldBase > CloneImpl(std::string_view newName) const final
Called by Clone(), which additionally copies the on-disk ID.
The on-storage metadata of an RNTuple.
RFieldDescriptorIterable GetFieldIterable(const RFieldDescriptor &fieldDesc) const
const RFieldDescriptor & GetFieldDescriptor(ROOT::DescriptorId_t fieldId) const
std::string GetTypeNameForComparison(const RFieldDescriptor &fieldDesc) const
Adjust the type name of the passed RFieldDescriptor for comparison with another renormalized type nam...
ROOT::DescriptorId_t FindFieldId(std::string_view fieldName, ROOT::DescriptorId_t parentId) const
Addresses a column element or field item relative to a particular cluster, instead of a global NTuple...
Template specializations for C++ std::pair.
void ReconcileOnDiskField(const RNTupleDescriptor &desc) final
For non-artificial fields, check compatibility of the in-memory field and the on-disk field.
RPairField(std::string_view fieldName, std::array< std::unique_ptr< RFieldBase >, 2 > itemFields)
std::unique_ptr< RFieldBase > CloneImpl(std::string_view newName) const final
Called by Clone(), which additionally copies the on-disk ID.
Allows for iterating over the elements of a proxied collection.
static RIteratorFuncs GetIteratorFuncs(TVirtualCollectionProxy *proxy, bool readFromDisk)
std::shared_ptr< TVirtualCollectionProxy > fProxy
RCollectionIterableOnce::RIteratorFuncs fIFuncsWrite
RProxiedCollectionDeleter(std::shared_ptr< TVirtualCollectionProxy > proxy)
void operator()(void *objPtr, bool dtorOnly) final
The field for a class representing a collection of elements via TVirtualCollectionProxy.
std::size_t GetValueSize() const final
What sizeof(T) for this type returns.
void GenerateColumns() final
Implementations in derived classes should create the backing columns corresponding to the field type ...
std::unique_ptr< RFieldBase > CloneImpl(std::string_view newName) const override
Called by Clone(), which additionally copies the on-disk ID.
const RColumnRepresentations & GetColumnRepresentations() const final
Implementations in derived classes should return a static RColumnRepresentations object.
void ConstructValue(void *where) const final
Constructs value in a given location of size at least GetValueSize(). Called by the base class' Creat...
RProxiedCollectionField(std::string_view fieldName, TClass *classp)
Constructor used when the value type of the collection is not known in advance, i....
RCollectionIterableOnce::RIteratorFuncs fIFuncsWrite
void AcceptVisitor(ROOT::Detail::RFieldVisitor &visitor) const final
RCollectionIterableOnce::RIteratorFuncs fIFuncsRead
Two sets of functions to operate on iterators, to be used depending on the access type.
std::shared_ptr< TVirtualCollectionProxy > fProxy
The collection proxy is needed by the deleters and thus defined as a shared pointer.
void ReadGlobalImpl(ROOT::NTupleSize_t globalIndex, void *to) final
std::size_t AppendImpl(const void *from) final
Operations on values of complex types, e.g.
std::unique_ptr< RDeleter > GetDeleter() const final
void ReconcileOnDiskField(const RNTupleDescriptor &desc) override
For non-artificial fields, check compatibility of the in-memory field and the on-disk field.
std::size_t GetAlignment() const final
What alignof(T) for this type returns.
std::vector< RValue > SplitValue(const RValue &value) const final
Creates the list of direct child values given an existing value for this field.
Template specializations for ROOT's RVec.
static unsigned char * ResizeRVec(void *rvec, std::size_t nItems, std::size_t itemSize, const RFieldBase *itemField, RDeleter *itemDeleter)
const_iterator begin() const
const_iterator end() const
The field for an untyped record.
void AttachItemFields(ContainerT &&itemFields)
std::vector< std::size_t > fOffsets
void ReconcileOnDiskField(const RNTupleDescriptor &desc) final
For non-artificial fields, check compatibility of the in-memory field and the on-disk field.
std::unique_ptr< RFieldBase > CloneImpl(std::string_view newName) const final
Called by Clone(), which additionally copies the on-disk ID.
RSetField(std::string_view fieldName, ESetType setType, std::unique_ptr< RFieldBase > itemField)
void operator()(void *objPtr, bool dtorOnly) final
RStreamerFieldDeleter(TClass *cl)
The field for a class using ROOT standard streaming.
ROOT::RExtraTypeInfoDescriptor GetExtraTypeInfo() const final
void ReadGlobalImpl(ROOT::NTupleSize_t globalIndex, void *to) final
ROOT::Internal::RNTupleSerializer::StreamerInfoMap_t fStreamerInfos
streamer info records seen during writing
void ReconcileOnDiskField(const RNTupleDescriptor &desc) final
For non-artificial fields, check compatibility of the in-memory field and the on-disk field.
std::uint32_t GetTypeVersion() const final
Indicates an evolution of the C++ type itself.
void GenerateColumns() final
Implementations in derived classes should create the backing columns corresponding to the field type ...
void ConstructValue(void *where) const final
Constructs value in a given location of size at least GetValueSize(). Called by the base class' Creat...
std::uint32_t GetTypeChecksum() const final
Return the current TClass reported checksum of this class. Only valid if kTraitTypeChecksum is set.
std::unique_ptr< RFieldBase > BeforeConnectPageSource(ROOT::Internal::RPageSource &source) final
Called by ConnectPageSource() before connecting; derived classes may override this as appropriate,...
std::unique_ptr< RFieldBase > CloneImpl(std::string_view newName) const final
Called by Clone(), which additionally copies the on-disk ID.
std::size_t AppendImpl(const void *from) final
Operations on values of complex types, e.g.
void AcceptVisitor(ROOT::Detail::RFieldVisitor &visitor) const final
RStreamerField(std::string_view fieldName, TClass *classp)
size_t GetAlignment() const final
What alignof(T) for this type returns.
const RColumnRepresentations & GetColumnRepresentations() const final
Implementations in derived classes should return a static RColumnRepresentations object.
size_t GetValueSize() const final
What sizeof(T) for this type returns.
Template specializations for C++ std::tuple.
void ReconcileOnDiskField(const RNTupleDescriptor &desc) final
For non-artificial fields, check compatibility of the in-memory field and the on-disk field.
RTupleField(std::string_view fieldName, std::vector< std::unique_ptr< RFieldBase > > itemFields)
std::unique_ptr< RFieldBase > CloneImpl(std::string_view newName) const final
Called by Clone(), which additionally copies the on-disk ID.
void operator()(void *objPtr, bool dtorOnly) final
Template specializations for C++ std::variant.
std::size_t AppendImpl(const void *from) final
Operations on values of complex types, e.g.
std::size_t GetAlignment() const final
What alignof(T) for this type returns.
static constexpr std::size_t kMaxVariants
std::vector< ROOT::Internal::RColumnIndex::ValueType > fNWritten
static std::uint8_t GetTag(const void *variantPtr, std::size_t tagOffset)
Extracts the index from an std::variant and transforms it into the 1-based index used for the switch ...
void GenerateColumns() final
Implementations in derived classes should create the backing columns corresponding to the field type ...
size_t fVariantOffset
In the std::variant memory layout, the actual union of types may start at an offset > 0.
std::unique_ptr< RFieldBase > CloneImpl(std::string_view newName) const final
Called by Clone(), which additionally copies the on-disk ID.
std::size_t GetValueSize() const final
What sizeof(T) for this type returns.
std::unique_ptr< RDeleter > GetDeleter() const final
void ReconcileOnDiskField(const RNTupleDescriptor &desc) final
For non-artificial fields, check compatibility of the in-memory field and the on-disk field.
const RColumnRepresentations & GetColumnRepresentations() const final
Implementations in derived classes should return a static RColumnRepresentations object.
void ConstructValue(void *where) const final
Constructs value in a given location of size at least GetValueSize(). Called by the base class' Creat...
size_t fTagOffset
In the std::variant memory layout, at which byte number is the index stored.
RVariantField(std::string_view name, const RVariantField &source)
void ReadGlobalImpl(ROOT::NTupleSize_t globalIndex, void *to) final
static void SetTag(void *variantPtr, std::size_t tagOffset, std::uint8_t tag)
void CommitClusterImpl() final
The concrete implementation of TBuffer for writing/reading to/from a ROOT file or socket.
TClass instances represent classes, structs and namespaces in the ROOT type system.
UInt_t GetCheckSum(ECheckSum code=kCurrentCheckSum) const
Call GetCheckSum with validity check.
Bool_t CanSplit() const
Return true if the data member of this TClass can be saved separately.
void Destructor(void *obj, Bool_t dtorOnly=kFALSE)
Explicitly call destructor for object.
size_t GetClassAlignment() const
Return the alignment requirement (in bytes) for objects of this class.
void BuildRealData(void *pointer=nullptr, Bool_t isTransient=kFALSE)
Build a full list of persistent data members.
const std::type_info * GetTypeInfo() const
TList * GetListOfDataMembers(Bool_t load=kTRUE)
Return list containing the TDataMembers of a class.
TList * GetListOfRealData() const
Int_t Size() const
Return size of object of this class.
TList * GetListOfBases()
Return list containing the TBaseClass(es) of a class.
TVirtualCollectionProxy * GetCollectionProxy() const
Return the proxy describing the collection (if any).
Int_t GetClassSize() const
Long_t ClassProperty() const
Return the C++ property of this class, eg.
Long_t Property() const override
Returns the properties of the TClass as a bit field stored as a Long_t value.
Version_t GetClassVersion() const
static TClass * GetClass(const char *name, Bool_t load=kTRUE, Bool_t silent=kFALSE)
Static method returning pointer to TClass of the specified class name.
All ROOT classes may have RTTI (run time type identification) support added.
The TEnum class implements the enum type.
static TEnum * GetEnum(const std::type_info &ti, ESearchAction sa=kALoadAndInterpLookup)
TObject * First() const override
Return the first object in the list. Returns 0 when list is empty.
const char * GetName() const override
Returns name of object.
Mother of all ROOT objects.
@ kIsOnHeap
object is on heap
@ kNotDeleted
object has not been deleted
@ kIsReferenced
if object is referenced by a TRef or TRefArray
The TRealData class manages the effective list of all data members for a given class.
RAII helper class that ensures that PushProxy() / PopProxy() are called when entering / leaving a C++...
Defines a common interface to inspect/change the contents of an object that represents a collection.
@ kNeedDelete
The collection contains directly or indirectly (via other collection) some pointers that need explici...
Abstract Interface class describing Streamer information for one class.
TRangeCast< T, false > TRangeStaticCast
TRangeStaticCast is an adapter class that allows the typed iteration through a TCollection.
void SetAllowFieldSubstitutions(RFieldZero &fieldZero, bool val)
std::tuple< unsigned char **, std::int32_t *, std::int32_t * > GetRVecDataMembers(void *rvecPtr)
Retrieve the addresses of the data members of a generic RVec from a pointer to the beginning of the R...
ROOT::RLogChannel & NTupleLog()
Log channel for RNTuple diagnostics.
void CallConnectPageSourceOnField(RFieldBase &, ROOT::Internal::RPageSource &)
std::string GetRNTupleSoARecord(const TClass *cl)
Checks if the "rntuple.SoARecord" class attribute is set in the dictionary.
bool NeedsMetaNameAsAlias(const std::string &metaNormalizedName, std::string &renormalizedAlias, bool isArgInTemplatedUserClass=false)
Checks if the meta normalized name is different from the RNTuple normalized name in a way that would ...
std::string GetTypeTraceReport(const RFieldBase &field, const RNTupleDescriptor &desc)
Prints the hierarchy of types with their field names and field IDs for the given in-memory field and ...
ERNTupleSerializationMode GetRNTupleSerializationMode(const TClass *cl)
std::string GetRenormalizedTypeName(const std::string &metaNormalizedName)
Given a type name normalized by ROOT meta, renormalize it for RNTuple. E.g., insert std::prefix.
constexpr bool IsValidAlignment(std::size_t align) noexcept
Return true if align is a valid C++ alignment value: strictly positive and a power of two.
std::uint64_t DescriptorId_t
Distriniguishes elements of the same type within a descriptor, e.g. different fields.
std::uint64_t NTupleSize_t
Integer type long enough to hold the maximum number of entries in a column.
constexpr DescriptorId_t kInvalidDescriptorId
ENTupleStructure
The fields in the RNTuple data model tree can carry different structural information about the type s...
void GetNormalizedName(std::string &norm_name, std::string_view name)
Return the normalized name.