pub struct PNCounterUpdate { /* private fields */ }Expand description
State for an increment/decrement distributed counter (PNCounter CRDT).
Internally uses two GCounters: one for increments (P), one for decrements (N). The value is P - N. Each is merged independently via pointwise max.
Implementations§
Source§impl PNCounterUpdate
impl PNCounterUpdate
Sourcepub fn num_inc_ranks(&self) -> usize
pub fn num_inc_ranks(&self) -> usize
Number of ranks that have contributed increments.
Sourcepub fn num_dec_ranks(&self) -> usize
pub fn num_dec_ranks(&self) -> usize
Number of ranks that have contributed decrements.
Trait Implementations§
Source§impl Clone for PNCounterUpdate
impl Clone for PNCounterUpdate
Source§fn clone(&self) -> PNCounterUpdate
fn clone(&self) -> PNCounterUpdate
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 PNCounterUpdate
impl Debug for PNCounterUpdate
Source§impl Default for PNCounterUpdate
impl Default for PNCounterUpdate
Source§fn default() -> PNCounterUpdate
fn default() -> PNCounterUpdate
Returns the “default value” for a type. Read more
Source§impl<'de> Deserialize<'de> for PNCounterUpdate
impl<'de> Deserialize<'de> for PNCounterUpdate
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>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl JoinSemilattice for PNCounterUpdate
impl JoinSemilattice for PNCounterUpdate
Source§impl Named for PNCounterUpdate
impl Named for PNCounterUpdate
Source§fn typename() -> &'static str
fn typename() -> &'static str
The globally unique type name for the type.
This should typically be the fully qualified Rust name of the type.
Source§fn typehash() -> u64
fn typehash() -> u64
A globally unique hash for this type.
TODO: actually enforce perfect hashing
Source§fn typeid() -> TypeId
fn typeid() -> TypeId
The TypeId for this type. TypeIds are unique only within a binary,
and should not be used for global identification.
Source§fn port() -> u64
fn port() -> u64
The globally unique port for this type. Typed ports are in the range
of 1<<63..1<<64-1.
Auto Trait Implementations§
impl Freeze for PNCounterUpdate
impl RefUnwindSafe for PNCounterUpdate
impl Send for PNCounterUpdate
impl Sync for PNCounterUpdate
impl Unpin for PNCounterUpdate
impl UnsafeUnpin for PNCounterUpdate
impl UnwindSafe for PNCounterUpdate
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,
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
Source§impl<A, M> Handler<IndexedErasedUnbound<M>> for A
impl<A, M> Handler<IndexedErasedUnbound<M>> for A
§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> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request§impl<L> LayerExt<L> for L
impl<L> LayerExt<L> for L
§fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
Applies the layer to a service and wraps it in [
Layered].