pub struct MerkleizedBatch<F: Family, D: Digest, K: Key, V: ValueEncoding> { /* private fields */ }Expand description
A speculative batch of operations whose root digest has been computed,
in contrast to UnmerkleizedBatch.
Implementations§
Source§impl<F: Family, D: Digest, K: Key, V: ValueEncoding> MerkleizedBatch<F, D, K, V>where
Operation<K, V>: EncodeShared,
impl<F: Family, D: Digest, K: Key, V: ValueEncoding> MerkleizedBatch<F, D, K, V>where
Operation<K, V>: EncodeShared,
Sourcepub async fn get<E, C, H, T>(
&self,
key: &K,
db: &Immutable<F, E, K, V, C, H, T>,
) -> Result<Option<V::Value>, Error<F>>where
E: Context,
C: Mutable<Item = Operation<K, V>> + Persistable<Error = JournalError>,
C::Item: EncodeShared,
H: CHasher<Digest = D>,
T: Translator,
pub async fn get<E, C, H, T>(
&self,
key: &K,
db: &Immutable<F, E, K, V, C, H, T>,
) -> Result<Option<V::Value>, Error<F>>where
E: Context,
C: Mutable<Item = Operation<K, V>> + Persistable<Error = JournalError>,
C::Item: EncodeShared,
H: CHasher<Digest = D>,
T: Translator,
Read through: local diff -> ancestor diffs -> committed DB.
Sourcepub fn new_batch<H>(self: &Arc<Self>) -> UnmerkleizedBatch<F, H, K, V>where
H: CHasher<Digest = D>,
pub fn new_batch<H>(self: &Arc<Self>) -> UnmerkleizedBatch<F, H, K, V>where
H: CHasher<Digest = D>,
Create a new speculative batch of operations with this batch as its parent.
All uncommitted ancestors in the chain must be kept alive until the child (or any
descendant) is merkleized. Dropping an uncommitted ancestor causes data
loss detected at apply_batch time.
Trait Implementations§
Source§impl<F: Clone + Family, D: Clone + Digest, K: Clone + Key, V: Clone + ValueEncoding> Clone for MerkleizedBatch<F, D, K, V>
impl<F: Clone + Family, D: Clone + Digest, K: Clone + Key, V: Clone + ValueEncoding> Clone for MerkleizedBatch<F, D, K, V>
Source§fn clone(&self) -> MerkleizedBatch<F, D, K, V>
fn clone(&self) -> MerkleizedBatch<F, D, K, V>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreAuto Trait Implementations§
impl<F, D, K, V> Freeze for MerkleizedBatch<F, D, K, V>
impl<F, D, K, V> !RefUnwindSafe for MerkleizedBatch<F, D, K, V>
impl<F, D, K, V> Send for MerkleizedBatch<F, D, K, V>
impl<F, D, K, V> Sync for MerkleizedBatch<F, D, K, V>
impl<F, D, K, V> Unpin for MerkleizedBatch<F, D, K, V>
impl<F, D, K, V> UnsafeUnpin for MerkleizedBatch<F, D, K, V>
impl<F, D, K, V> !UnwindSafe for MerkleizedBatch<F, D, K, V>
Blanket Implementations§
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
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> FutureExt for T
impl<T> FutureExt for T
Source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
Source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
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> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more