pub struct State<K, V, T, D> {
pub(crate) applier_version: Version,
pub(crate) shard_id: ShardId,
pub(crate) seqno: SeqNo,
pub(crate) collections: StateCollections<T>,
pub(crate) _phantom: PhantomData<fn() -> (K, V, D)>,
}
Fields
applier_version: Version
shard_id: ShardId
seqno: SeqNo
collections: StateCollections<T>
_phantom: PhantomData<fn() -> (K, V, D)>
Implementations
sourceimpl<K, V, T, D> State<K, V, T, D> where
K: Codec,
V: Codec,
T: Timestamp + Lattice + Codec64,
D: Codec64,
impl<K, V, T, D> State<K, V, T, D> where
K: Codec,
V: Codec,
T: Timestamp + Lattice + Codec64,
D: Codec64,
sourceimpl<K, V, T, D> State<K, V, T, D> where
K: Codec,
V: Codec,
T: Timestamp + Lattice + Codec64,
D: Codec64,
impl<K, V, T, D> State<K, V, T, D> where
K: Codec,
V: Codec,
T: Timestamp + Lattice + Codec64,
D: Codec64,
fn try_from(
x: ProtoStateRollup
) -> Result<Result<Self, CodecMismatch>, TryFromProtoError>
sourceimpl<K, V, T, D> State<K, V, T, D> where
K: Codec,
V: Codec,
T: Timestamp + Lattice + Codec64,
D: Codec64,
impl<K, V, T, D> State<K, V, T, D> where
K: Codec,
V: Codec,
T: Timestamp + Lattice + Codec64,
D: Codec64,
pub fn new(applier_version: Version, shard_id: ShardId) -> Self
pub fn shard_id(&self) -> ShardId
pub fn seqno(&self) -> SeqNo
pub fn since(&self) -> &Antichain<T>
pub fn upper(&self) -> &Antichain<T>
pub fn batch_count(&self) -> usize
fn seqno_since(&self) -> SeqNo
pub fn maybe_gc(&mut self, is_write: bool) -> Option<(SeqNo, SeqNo)>
sourcepub fn seqnos_held(&self) -> usize
pub fn seqnos_held(&self) -> usize
Return the number of gc-ineligible state versions.
pub fn clone_apply<R, E, WorkFn>(
&self,
build_version: &Version,
work_fn: &mut WorkFn
) -> ControlFlow<E, (R, Self)> where
WorkFn: FnMut(SeqNo, &mut StateCollections<T>) -> ControlFlow<E, R>,
sourcepub fn snapshot(
&self,
as_of: &Antichain<T>
) -> Result<Result<Vec<HollowBatch<T>>, Upper<T>>, Since<T>>
pub fn snapshot(
&self,
as_of: &Antichain<T>
) -> Result<Result<Vec<HollowBatch<T>>, Upper<T>>, Since<T>>
Returns the batches that contain updates up to (and including) the given as_of
. The
result Vec
contains blob keys, along with a Description
of what updates in the
referenced parts are valid to read.
pub fn verify_listen(
&self,
as_of: &Antichain<T>
) -> Result<Result<(), Upper<T>>, Since<T>>
pub fn next_listen_batch(
&self,
frontier: &Antichain<T>
) -> Option<HollowBatch<T>>
pub fn handles_needing_expiration(
&self,
now_ms: EpochMillis
) -> (Vec<ReaderId>, Vec<WriterId>)
Trait Implementations
sourceimpl<K, V, T, D> Codec for State<K, V, T, D> where
K: Codec,
V: Codec,
T: Timestamp + Lattice + Codec64,
D: Codec64,
impl<K, V, T, D> Codec for State<K, V, T, D> where
K: Codec,
V: Codec,
T: Timestamp + Lattice + Codec64,
D: Codec64,
sourceimpl<K, V, T, D> RustType<ProtoStateRollup> for State<K, V, T, D> where
K: Codec,
V: Codec,
T: Timestamp + Lattice + Codec64,
D: Codec64,
impl<K, V, T, D> RustType<ProtoStateRollup> for State<K, V, T, D> where
K: Codec,
V: Codec,
T: Timestamp + Lattice + Codec64,
D: Codec64,
sourcefn into_proto(&self) -> ProtoStateRollup
fn into_proto(&self) -> ProtoStateRollup
Convert a Self
into a Proto
value.
sourcefn from_proto(proto: ProtoStateRollup) -> Result<Self, TryFromProtoError>
fn from_proto(proto: ProtoStateRollup) -> Result<Self, TryFromProtoError>
Consume and convert a Proto
back into a Self
value. Read more
Auto Trait Implementations
impl<K, V, T, D> RefUnwindSafe for State<K, V, T, D> where
T: RefUnwindSafe,
impl<K, V, T, D> Send for State<K, V, T, D> where
T: Send,
impl<K, V, T, D> Sync for State<K, V, T, D> where
T: Sync,
impl<K, V, T, D> Unpin for State<K, V, T, D> where
T: Unpin,
impl<K, V, T, D> UnwindSafe for State<K, V, T, D> where
T: UnwindSafe,
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> FutureExt for T
impl<T> FutureExt for T
sourcefn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
sourcefn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
sourceimpl<T> Instrument for T
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
sourcefn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
sourceimpl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
sourcefn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message T
in a tonic::Request
sourceimpl<P, R> ProtoType<R> for P where
R: RustType<P>,
impl<P, R> ProtoType<R> for P where
R: RustType<P>,
sourcefn into_rust(self) -> Result<R, TryFromProtoError>
fn into_rust(self) -> Result<R, TryFromProtoError>
See RustType::from_proto
.
sourcefn from_rust(rust: &R) -> P
fn from_rust(rust: &R) -> P
See RustType::into_proto
.
sourceimpl<T> WithSubscriber for T
impl<T> WithSubscriber for T
sourcefn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
Attaches the provided Subscriber
to this type, returning a
WithDispatch
wrapper. Read more
sourcefn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Attaches the current default Subscriber
to this type, returning a
WithDispatch
wrapper. Read more