pub enum WalOperation {
Put {
key: Vec<u8>,
value: Vec<u8>,
},
Delete {
key: Vec<u8>,
},
Checkpoint {
id: u64,
},
Commit {
offsets: HashMap<String, u64>,
watermark: Option<i64>,
},
EpochBarrier {
epoch: u64,
},
}Expand description
Operations that can be logged in the WAL.
Variants§
Put
Put a key-value pair.
Delete
Delete a key.
Checkpoint
Checkpoint marker.
Commit
Commit offsets for exactly-once semantics.
Fields
EpochBarrier
Barrier for epoch boundary.
Trait Implementations§
Source§impl Archive for WalOperation
impl Archive for WalOperation
Source§type Resolver = WalOperationResolver
type Resolver = WalOperationResolver
The resolver for this type. It must contain all the additional
information from serializing needed to make the archived type from
the normal type.
Source§fn resolve(
&self,
resolver: <Self as Archive>::Resolver,
out: Place<<Self as Archive>::Archived>,
)
fn resolve( &self, resolver: <Self as Archive>::Resolver, out: Place<<Self as Archive>::Archived>, )
Creates the archived version of this value at the given position and
writes it to the given output. Read more
§const COPY_OPTIMIZATION: CopyOptimization<Self> = _
const COPY_OPTIMIZATION: CopyOptimization<Self> = _
An optimization flag that allows the bytes of this type to be copied
directly to a writer instead of calling
serialize. Read moreSource§impl Clone for WalOperation
impl Clone for WalOperation
Source§fn clone(&self) -> WalOperation
fn clone(&self) -> WalOperation
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 moreSource§impl Debug for WalOperation
impl Debug for WalOperation
Source§impl<__D: Fallible + ?Sized> Deserialize<WalOperation, __D> for Archived<WalOperation>where
Vec<u8>: Archive,
<Vec<u8> as Archive>::Archived: Deserialize<Vec<u8>, __D>,
u64: Archive,
<u64 as Archive>::Archived: Deserialize<u64, __D>,
HashMap<String, u64>: Archive,
<HashMap<String, u64> as Archive>::Archived: Deserialize<HashMap<String, u64>, __D>,
Option<i64>: Archive,
<Option<i64> as Archive>::Archived: Deserialize<Option<i64>, __D>,
impl<__D: Fallible + ?Sized> Deserialize<WalOperation, __D> for Archived<WalOperation>where
Vec<u8>: Archive,
<Vec<u8> as Archive>::Archived: Deserialize<Vec<u8>, __D>,
u64: Archive,
<u64 as Archive>::Archived: Deserialize<u64, __D>,
HashMap<String, u64>: Archive,
<HashMap<String, u64> as Archive>::Archived: Deserialize<HashMap<String, u64>, __D>,
Option<i64>: Archive,
<Option<i64> as Archive>::Archived: Deserialize<Option<i64>, __D>,
Source§fn deserialize(
&self,
deserializer: &mut __D,
) -> Result<WalOperation, <__D as Fallible>::Error>
fn deserialize( &self, deserializer: &mut __D, ) -> Result<WalOperation, <__D as Fallible>::Error>
Deserializes using the given deserializer
Source§impl PartialEq for WalOperation
impl PartialEq for WalOperation
Source§impl<__S: Fallible + ?Sized> Serialize<__S> for WalOperation
impl<__S: Fallible + ?Sized> Serialize<__S> for WalOperation
impl Eq for WalOperation
impl StructuralPartialEq for WalOperation
Auto Trait Implementations§
impl Freeze for WalOperation
impl RefUnwindSafe for WalOperation
impl Send for WalOperation
impl Sync for WalOperation
impl Unpin for WalOperation
impl UnsafeUnpin for WalOperation
impl UnwindSafe for WalOperation
Blanket Implementations§
§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
§impl<T> ArchiveUnsized for Twhere
T: Archive,
impl<T> ArchiveUnsized for Twhere
T: Archive,
§type Archived = <T as Archive>::Archived
type Archived = <T as Archive>::Archived
The archived counterpart of this type. Unlike
Archive, it may be
unsized. Read more§fn archived_metadata(
&self,
) -> <<T as ArchiveUnsized>::Archived as ArchivePointee>::ArchivedMetadata
fn archived_metadata( &self, ) -> <<T as ArchiveUnsized>::Archived as ArchivePointee>::ArchivedMetadata
Creates the archived version of the metadata for this value.
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,
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§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§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2where
T: SharedNiching<N1, N2>,
N1: Niching<T>,
N2: Niching<T>,
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2where
T: SharedNiching<N1, N2>,
N1: Niching<T>,
N2: Niching<T>,
§impl<T> Pointee for T
impl<T> Pointee for T
§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
§impl<T> Scope for T
impl<T> Scope for T
§impl<T, S> SerializeUnsized<S> for Twhere
T: Serialize<S>,
S: Fallible + Writer + ?Sized,
impl<T, S> SerializeUnsized<S> for Twhere
T: Serialize<S>,
S: Fallible + Writer + ?Sized,
§fn serialize_unsized(
&self,
serializer: &mut S,
) -> Result<usize, <S as Fallible>::Error>
fn serialize_unsized( &self, serializer: &mut S, ) -> Result<usize, <S as Fallible>::Error>
Writes the object and returns the position of the archived type.