Struct ruserf_types::PushPullMessageRef
source · pub struct PushPullMessageRef<'a, I> {
pub ltime: LamportTime,
pub status_ltimes: &'a IndexMap<I, LamportTime>,
pub left_members: &'a IndexSet<I>,
pub event_ltime: LamportTime,
pub events: &'a [Option<UserEvents>],
pub query_ltime: LamportTime,
}Expand description
Used when doing a state exchange. This is a relatively large message, but is sent infrequently
Fields§
§ltime: LamportTimeCurrent node lamport time
status_ltimes: &'a IndexMap<I, LamportTime>Maps the node to its status time
left_members: &'a IndexSet<I>List of left nodes
event_ltime: LamportTimeLamport time for event clock
events: &'a [Option<UserEvents>]Recent events
query_ltime: LamportTimeLamport time for query clock
Trait Implementations§
source§impl<'a, I, A> AsMessageRef<I, A> for PushPullMessageRef<'a, I>
impl<'a, I, A> AsMessageRef<I, A> for PushPullMessageRef<'a, I>
source§fn as_message_ref(&self) -> SerfMessageRef<'_, I, A>
fn as_message_ref(&self) -> SerfMessageRef<'_, I, A>
Converts this type into a shared reference of the (usually inferred) input type.
source§impl<'a, I> Clone for PushPullMessageRef<'a, I>
impl<'a, I> Clone for PushPullMessageRef<'a, I>
source§impl<'a, I: Debug> Debug for PushPullMessageRef<'a, I>
impl<'a, I: Debug> Debug for PushPullMessageRef<'a, I>
source§impl<'a, I> Encodable for PushPullMessageRef<'a, I>where
I: Transformable,
impl<'a, I> Encodable for PushPullMessageRef<'a, I>where
I: Transformable,
source§fn encoded_len(&self) -> usize
fn encoded_len(&self) -> usize
Returns the encoded length of the message
source§fn encode(
&self,
dst: &mut [u8]
) -> Result<usize, PushPullMessageTransformError<I>>
fn encode( &self, dst: &mut [u8] ) -> Result<usize, PushPullMessageTransformError<I>>
Encodes the message into the given buffer
§type Error = PushPullMessageTransformError<I>
type Error = PushPullMessageTransformError<I>
The error type returned when encoding or decoding fails.
source§fn encode_to_vec(&self) -> Result<Vec<u8>, Self::Error>
fn encode_to_vec(&self) -> Result<Vec<u8>, Self::Error>
Encodes the value into a vec for transmission.
source§impl<'a, I> From<&'a PushPullMessage<I>> for PushPullMessageRef<'a, I>
impl<'a, I> From<&'a PushPullMessage<I>> for PushPullMessageRef<'a, I>
source§fn from(msg: &'a PushPullMessage<I>) -> Self
fn from(msg: &'a PushPullMessage<I>) -> Self
Converts to this type from the input type.
source§impl<'a, I> From<&'a mut PushPullMessage<I>> for PushPullMessageRef<'a, I>
impl<'a, I> From<&'a mut PushPullMessage<I>> for PushPullMessageRef<'a, I>
source§fn from(msg: &'a mut PushPullMessage<I>) -> Self
fn from(msg: &'a mut PushPullMessage<I>) -> Self
Converts to this type from the input type.
source§impl<'a, I> Serialize for PushPullMessageRef<'a, I>where
I: Serialize,
impl<'a, I> Serialize for PushPullMessageRef<'a, I>where
I: Serialize,
impl<'a, I> Copy for PushPullMessageRef<'a, I>
Auto Trait Implementations§
impl<'a, I> Freeze for PushPullMessageRef<'a, I>
impl<'a, I> RefUnwindSafe for PushPullMessageRef<'a, I>where
I: RefUnwindSafe,
impl<'a, I> Send for PushPullMessageRef<'a, I>where
I: Sync,
impl<'a, I> Sync for PushPullMessageRef<'a, I>where
I: Sync,
impl<'a, I> Unpin for PushPullMessageRef<'a, I>
impl<'a, I> UnwindSafe for PushPullMessageRef<'a, I>where
I: RefUnwindSafe,
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> 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