22 switch (fieldValueSize) {
23 case 1: value = *
reinterpret_cast<std::uint8_t *
>(valuePtr);
break;
24 case 2: value = *
reinterpret_cast<std::uint16_t *
>(valuePtr);
break;
25 case 4: value = *
reinterpret_cast<std::uint32_t *
>(valuePtr);
break;
26 case 8: value = *
reinterpret_cast<std::uint64_t *
>(valuePtr);
break;
39 static const std::unordered_set<std::string> allowedTypes = {
"std::int8_t",
"std::int16_t",
"std::int32_t",
40 "std::int64_t",
"std::uint8_t",
"std::uint16_t",
41 "std::uint32_t",
"std::uint64_t"};
46 std::vector<std::unique_ptr<ROOT::RFieldBase>> fields;
47 std::vector<ROOT::RFieldBase::RValue> fieldValues;
51 auto fieldId = desc->FindFieldId(fieldName);
53 throw RException(
R__FAIL(
"could not find join field \"" + std::string(fieldName) +
"\" in RNTuple \"" +
56 const auto &fieldDesc = desc->GetFieldDescriptor(fieldId);
58 if (allowedTypes.find(fieldDesc.GetTypeName()) == allowedTypes.end()) {
59 throw RException(
R__FAIL(
"cannot use field \"" + fieldName +
"\" with type \"" + fieldDesc.GetTypeName() +
60 "\" in join table: only integral types are allowed"));
63 auto field = fieldDesc.CreateField(desc.GetRef());
66 fieldValues.emplace_back(field->CreateValue());
68 fields.emplace_back(std::move(field));
71 std::vector<JoinValue_t> castJoinValues;
75 castJoinValues.clear();
77 for (
auto &fieldValue : fieldValues) {
81 auto valuePtr = fieldValue.GetPtr<
void>();
82 castJoinValues.push_back(CastValuePtr(valuePtr.get(), fieldValue.GetField().GetValueSize()));
89const std::vector<ROOT::NTupleSize_t> *
90ROOT ::Experimental::Internal::RNTupleJoinTable::REntryMapping::GetEntryIndexes(std::vector<void *> valuePtrs)
const
93 throw RException(
R__FAIL(
"number of value pointers must match number of join fields"));
95 std::vector<JoinValue_t> castJoinValues;
96 castJoinValues.reserve(valuePtrs.size());
98 for (
unsigned i = 0; i < valuePtrs.size(); ++i) {
103 return &entries->second;
111std::unique_ptr<ROOT::Experimental::Internal::RNTupleJoinTable>
122 fPartitions[partitionKey].emplace_back(std::move(joinMapping));
131 for (
const auto &joinMapping : partition.second) {
132 auto entriesForMapping = joinMapping->GetEntryIndexes(valuePtrs);
133 if (entriesForMapping) {
134 return (*entriesForMapping)[0];
#define R__FAIL(msg)
Short-hand to return an RResult<T> in an error state; the RError is implicitly converted into RResult...
Provides a mapping from one or several join field values to an entry index.
REntryMapping(ROOT::Internal::RPageSource &pageSource, const std::vector< std::string > &joinFieldNames, ROOT::NTupleSize_t entryOffset=0)
Create a new entry mapping.
std::vector< std::size_t > fJoinFieldValueSizes
The size (in bytes) for each join field, corresponding to fJoinFieldNames.
std::vector< std::string > fJoinFieldNames
Names of the join fields used for the mapping to their respective entry indexes.
std::unordered_map< RCombinedJoinFieldValue, std::vector< ROOT::NTupleSize_t >, RCombinedJoinFieldValueHash > fMapping
The mapping itself.
Builds a join table on one or several fields of an RNTuple so it can be joined onto other RNTuples.
static std::unique_ptr< RNTupleJoinTable > Create(const std::vector< std::string > &joinFieldNames)
Create an RNTupleJoinTable from an existing RNTuple.
std::vector< std::string > fJoinFieldNames
Names of the join fields used for the mapping to their respective entry indexes.
std::uint64_t PartitionKey_t
std::uint64_t JoinValue_t
ROOT::NTupleSize_t GetEntryIndex(const std::vector< void * > &valuePtrs) const
Get an entry index (if it exists) for the given join field value(s), from any partition.
RNTupleJoinTable & Add(ROOT::Internal::RPageSource &pageSource, PartitionKey_t partitionKey=kDefaultPartitionKey, ROOT::NTupleSize_t entryOffset=0)
Add an entry mapping to the join table.
RNTupleJoinTable(const std::vector< std::string > &joinFieldNames)
Create an a new RNTupleJoinTable for the RNTuple represented by the provided page source.
std::unordered_map< PartitionKey_t, std::vector< std::unique_ptr< REntryMapping > > > fPartitions
Partitions of one or multiple entry mappings.
Abstract interface to read data from an ntuple.
void Attach(ROOT::Internal::RNTupleSerializer::EDescriptorDeserializeMode mode=ROOT::Internal::RNTupleSerializer::EDescriptorDeserializeMode::kForReading)
Open the physical storage container and deserialize header and footer.
const RSharedDescriptorGuard GetSharedDescriptorGuard() const
Takes the read lock for the descriptor.
ROOT::NTupleSize_t GetNEntries()
const std::string & GetNTupleName() const
Returns the NTuple name.
Base class for all ROOT issued exceptions.
void CallConnectPageSourceOnField(RFieldBase &, ROOT::Internal::RPageSource &)
constexpr NTupleSize_t kInvalidNTupleIndex
std::uint64_t NTupleSize_t
Integer type long enough to hold the maximum number of entries in a column.
constexpr DescriptorId_t kInvalidDescriptorId
Container for the combined hashes of join field values.