pub enum EngineKeySet {
Document {
collection: String,
surrogates: SortedVec<u32>,
},
Vector {
collection: String,
surrogates: SortedVec<u32>,
},
Kv {
collection: String,
keys: SortedVec<Vec<u8>>,
},
Edge {
collection: String,
edges: SortedVec<(u32, u32)>,
},
}Expand description
A typed key set for one engine within a read or write set.
Keys are normalized to surrogates (or byte keys for KV) at admission, so all engine-specific naming is resolved upstream of the sequencer.
Variants§
Document
Document engine (schemaless or strict): identified by surrogate.
Vector
Vector engine: identified by surrogate.
Kv
Key-Value engine: identified by raw byte keys.
Edge
Graph edge engine: identified by (src_surrogate, dst_surrogate) pairs.
Implementations§
Source§impl EngineKeySet
impl EngineKeySet
Sourcepub fn serialized_size_hint(&self) -> usize
pub fn serialized_size_hint(&self) -> usize
O(1) estimate of the serialized byte size of this key set.
Used by the dependent-read cap check at sequencer admission to bound
the total bytes that would be Raft-replicated in a CalvinReadResult
entry. This is an estimate, not an exact count; do NOT use it as a
correctness check — only as a pre-flight guard.
Sourcepub fn collection(&self) -> &str
pub fn collection(&self) -> &str
The collection this key set belongs to.
Trait Implementations§
Source§impl Clone for EngineKeySet
impl Clone for EngineKeySet
Source§fn clone(&self) -> EngineKeySet
fn clone(&self) -> EngineKeySet
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for EngineKeySet
impl Debug for EngineKeySet
Source§impl<'de> Deserialize<'de> for EngineKeySet
impl<'de> Deserialize<'de> for EngineKeySet
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
impl Eq for EngineKeySet
Source§impl<'__msgpack_de> FromMessagePack<'__msgpack_de> for EngineKeySet
impl<'__msgpack_de> FromMessagePack<'__msgpack_de> for EngineKeySet
Source§impl PartialEq for EngineKeySet
impl PartialEq for EngineKeySet
Source§fn eq(&self, other: &EngineKeySet) -> bool
fn eq(&self, other: &EngineKeySet) -> bool
self and other values to be equal, and is used by ==.Source§impl Serialize for EngineKeySet
impl Serialize for EngineKeySet
impl StructuralPartialEq for EngineKeySet
Auto Trait Implementations§
impl Freeze for EngineKeySet
impl RefUnwindSafe for EngineKeySet
impl Send for EngineKeySet
impl Sync for EngineKeySet
impl Unpin for EngineKeySet
impl UnsafeUnpin for EngineKeySet
impl UnwindSafe for EngineKeySet
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> DeserializeOwned for Twhere
T: for<'de> Deserialize<'de>,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
impl<T> FromMessagePackOwned for Twhere
T: for<'a> FromMessagePack<'a>,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
out indicating that a T is niched.impl<T> Read<Exclusive, BecauseExclusive> for Twhere
T: ?Sized,
impl<T> Scalar for T
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.