The serialization context is used for the piecewise serialization of a descriptor.
During header serialization, the mapping of in-memory field and column IDs to on-disk IDs is built so that it can be used for the footer serialization in a second step.
Definition at line 92 of file RNTupleSerialize.hxx.
Public Member Functions | |
void | BeginHeaderExtension () |
Mark the first on-disk field ID that is part of the schema extension. | |
std::size_t | GetHeaderExtensionOffset () const |
Return the offset of the first element in fOnDisk2MemFieldIDs that is part of the schema extension. | |
std::uint64_t | GetHeaderSize () const |
std::uint64_t | GetHeaderXxHash3 () const |
DescriptorId_t | GetMemClusterGroupId (DescriptorId_t onDiskId) const |
DescriptorId_t | GetMemClusterId (DescriptorId_t onDiskId) const |
DescriptorId_t | GetMemColumnId (DescriptorId_t onDiskId) const |
DescriptorId_t | GetMemFieldId (DescriptorId_t onDiskId) const |
DescriptorId_t | GetOnDiskClusterGroupId (DescriptorId_t memId) const |
DescriptorId_t | GetOnDiskClusterId (DescriptorId_t memId) const |
DescriptorId_t | GetOnDiskColumnId (DescriptorId_t memId) const |
DescriptorId_t | GetOnDiskFieldId (DescriptorId_t memId) const |
const std::vector< DescriptorId_t > & | GetOnDiskFieldList () const |
Return a vector containing the in-memory field ID for each on-disk counterpart, in order, i.e. | |
DescriptorId_t | MapClusterGroupId (DescriptorId_t memId) |
DescriptorId_t | MapClusterId (DescriptorId_t memId) |
DescriptorId_t | MapColumnId (DescriptorId_t memId) |
Map an in-memory column ID to its on-disk counterpart. | |
DescriptorId_t | MapFieldId (DescriptorId_t memId) |
Map an in-memory field ID to its on-disk counterpart. | |
void | MapSchema (const RNTupleDescriptor &desc, bool forHeaderExtension) |
Map in-memory field and column IDs to their on-disk counterparts. | |
void | SetHeaderSize (std::uint64_t size) |
void | SetHeaderXxHash3 (std::uint64_t xxhash3) |
Private Attributes | |
std::size_t | fHeaderExtensionOffset = -1U |
std::uint64_t | fHeaderSize = 0 |
std::uint64_t | fHeaderXxHash3 = 0 |
std::map< DescriptorId_t, DescriptorId_t > | fMem2OnDiskClusterGroupIDs |
std::map< DescriptorId_t, DescriptorId_t > | fMem2OnDiskClusterIDs |
std::map< DescriptorId_t, DescriptorId_t > | fMem2OnDiskColumnIDs |
std::map< DescriptorId_t, DescriptorId_t > | fMem2OnDiskFieldIDs |
std::vector< DescriptorId_t > | fOnDisk2MemClusterGroupIDs |
std::vector< DescriptorId_t > | fOnDisk2MemClusterIDs |
std::vector< DescriptorId_t > | fOnDisk2MemColumnIDs |
std::vector< DescriptorId_t > | fOnDisk2MemFieldIDs |
#include <ROOT/RNTupleSerialize.hxx>
|
inline |
Mark the first on-disk field ID that is part of the schema extension.
Definition at line 166 of file RNTupleSerialize.hxx.
|
inline |
Return the offset of the first element in fOnDisk2MemFieldIDs
that is part of the schema extension.
Definition at line 168 of file RNTupleSerialize.hxx.
|
inline |
Definition at line 108 of file RNTupleSerialize.hxx.
|
inline |
Definition at line 110 of file RNTupleSerialize.hxx.
|
inline |
Definition at line 157 of file RNTupleSerialize.hxx.
|
inline |
Definition at line 156 of file RNTupleSerialize.hxx.
|
inline |
Definition at line 155 of file RNTupleSerialize.hxx.
|
inline |
Definition at line 154 of file RNTupleSerialize.hxx.
|
inline |
Definition at line 150 of file RNTupleSerialize.hxx.
|
inline |
Definition at line 149 of file RNTupleSerialize.hxx.
|
inline |
Definition at line 148 of file RNTupleSerialize.hxx.
|
inline |
Definition at line 147 of file RNTupleSerialize.hxx.
|
inline |
Return a vector containing the in-memory field ID for each on-disk counterpart, in order, i.e.
the i
-th value corresponds to the in-memory field ID for i
-th on-disk ID
Definition at line 164 of file RNTupleSerialize.hxx.
|
inline |
Definition at line 135 of file RNTupleSerialize.hxx.
|
inline |
Definition at line 129 of file RNTupleSerialize.hxx.
|
inline |
Map an in-memory column ID to its on-disk counterpart.
It is allowed to call this function multiple times for the same memId
, in which case the return value is the on-disk ID assigned on the first call.
Definition at line 122 of file RNTupleSerialize.hxx.
|
inline |
Map an in-memory field ID to its on-disk counterpart.
It is allowed to call this function multiple times for the same memId
, in which case the return value is the on-disk ID assigned on the first call.
Definition at line 113 of file RNTupleSerialize.hxx.
void ROOT::Experimental::Internal::RNTupleSerializer::RContext::MapSchema | ( | const RNTupleDescriptor & | desc, |
bool | forHeaderExtension | ||
) |
Map in-memory field and column IDs to their on-disk counterparts.
This function is unconditionally called during header serialization. This function must be manually called after an incremental schema update as page list serialization requires all columns to be mapped.
Definition at line 1020 of file RNTupleSerialize.cxx.
|
inline |
Definition at line 107 of file RNTupleSerialize.hxx.
|
inline |
Definition at line 109 of file RNTupleSerialize.hxx.
|
private |
Definition at line 104 of file RNTupleSerialize.hxx.
|
private |
Definition at line 94 of file RNTupleSerialize.hxx.
|
private |
Definition at line 95 of file RNTupleSerialize.hxx.
|
private |
Definition at line 99 of file RNTupleSerialize.hxx.
|
private |
Definition at line 98 of file RNTupleSerialize.hxx.
|
private |
Definition at line 97 of file RNTupleSerialize.hxx.
|
private |
Definition at line 96 of file RNTupleSerialize.hxx.
|
private |
Definition at line 103 of file RNTupleSerialize.hxx.
|
private |
Definition at line 102 of file RNTupleSerialize.hxx.
|
private |
Definition at line 101 of file RNTupleSerialize.hxx.
|
private |
Definition at line 100 of file RNTupleSerialize.hxx.