pub struct Member<T> { /* private fields */ }
Expand description
A Cluster Member. Also often called “cluster update”.
A Member
represents Foca’s snapshot knowledge about an
crate::Identity
. An individual cluster update is simply a
serialized Member which other Foca instances receive and use to
update their own cluster state representation.
Implementations§
Source§impl<T> Member<T>
impl<T> Member<T>
Sourcepub fn new(id: T, incarnation: Incarnation, state: State) -> Self
pub fn new(id: T, incarnation: Incarnation, state: State) -> Self
Initializes a new member.
id
is an identity used to uniquely identify an individual
cluster member (say, a primary key).
Sourcepub fn alive(id: T) -> Self
pub fn alive(id: T) -> Self
Shortcut for initializing a member as State::Alive
.
Sourcepub fn incarnation(&self) -> Incarnation
pub fn incarnation(&self) -> Incarnation
Getter for the member’s Incarnation
Trait Implementations§
Source§impl<'de, T> Deserialize<'de> for Member<T>where
T: Deserialize<'de>,
impl<'de, T> Deserialize<'de> for Member<T>where
T: Deserialize<'de>,
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
impl<T: Eq> Eq for Member<T>
impl<T> StructuralPartialEq for Member<T>
Auto Trait Implementations§
impl<T> Freeze for Member<T>where
T: Freeze,
impl<T> RefUnwindSafe for Member<T>where
T: RefUnwindSafe,
impl<T> Send for Member<T>where
T: Send,
impl<T> Sync for Member<T>where
T: Sync,
impl<T> Unpin for Member<T>where
T: Unpin,
impl<T> UnwindSafe for Member<T>where
T: UnwindSafe,
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