pub struct Node<I, A> { /* private fields */ }
Expand description
Node is consist of id and address, which can be used as a identifier in a distributed system.
Implementations§
Source§impl<I, A> Node<I, A>
impl<I, A> Node<I, A>
Sourcepub fn set_address(&mut self, address: A) -> &mut Node<I, A>
pub fn set_address(&mut self, address: A) -> &mut Node<I, A>
Set the address of the node.
Sourcepub fn with_address(self, address: A) -> Node<I, A>
pub fn with_address(self, address: A) -> Node<I, A>
Set the address of the node. (Builder pattern)
Sourcepub fn into_components(self) -> (I, A)
pub fn into_components(self) -> (I, A)
Consumes the node and returns the id and address of the node.
Sourcepub fn map_address<U>(self, f: impl FnOnce(A) -> U) -> Node<I, U>
pub fn map_address<U>(self, f: impl FnOnce(A) -> U) -> Node<I, U>
Maps an Node<I, A>
to Node<I, U>
by applying a function to the current node.
§Example
use nodecraft::Node;
let node = Node::new("test", 100u64);
let node = node.map_address(|address| address.to_string());
assert_eq!(node.address(), "100");
Sourcepub fn map_id<U>(self, f: impl FnOnce(I) -> U) -> Node<U, A>
pub fn map_id<U>(self, f: impl FnOnce(I) -> U) -> Node<U, A>
Maps an Node<I, A>
to Node<U, A>
by applying a function to the current node.
§Example
use nodecraft::Node;
let node = Node::new(1u64, 100u64);
let node = node.map_id(|id| id.to_string());
assert_eq!(node.id(), "1");
Sourcepub fn map<U, V>(self, f: impl FnOnce(I, A) -> (U, V)) -> Node<U, V>
pub fn map<U, V>(self, f: impl FnOnce(I, A) -> (U, V)) -> Node<U, V>
Maps an Node<I, A>
to Node<U, V>
by applying a function to the current node.
§Example
use nodecraft::Node;
let node = Node::new(1u64, 100u64);
let node = node.map(|id, address| (id.to_string(), address.to_string()));
assert_eq!(node.id(), "1");
assert_eq!(node.address(), "100");
Trait Implementations§
Source§impl<I, A> CheapClone for Node<I, A>where
I: CheapClone,
A: CheapClone,
impl<I, A> CheapClone for Node<I, A>where
I: CheapClone,
A: CheapClone,
Source§fn cheap_clone(&self) -> Node<I, A>
fn cheap_clone(&self) -> Node<I, A>
Returns a copy of the value.
Source§impl<I, A> Data for Node<I, A>
impl<I, A> Data for Node<I, A>
Source§type Ref<'a> = Node<<I as Data>::Ref<'a>, <A as Data>::Ref<'a>>
type Ref<'a> = Node<<I as Data>::Ref<'a>, <A as Data>::Ref<'a>>
The reference type of the data.
Source§fn from_ref(
val: <Node<I, A> as Data>::Ref<'_>,
) -> Result<Node<I, A>, DecodeError>
fn from_ref( val: <Node<I, A> as Data>::Ref<'_>, ) -> Result<Node<I, A>, DecodeError>
Converts the reference type to the owned type.
Source§fn encoded_len(&self) -> usize
fn encoded_len(&self) -> usize
Returns the encoded length of the data only considering the data itself, (e.g. no length prefix, no wire type).
Source§fn encode(&self, buf: &mut [u8]) -> Result<usize, EncodeError>
fn encode(&self, buf: &mut [u8]) -> Result<usize, EncodeError>
Encodes the message to a buffer. Read more
Source§fn encoded_len_with_length_delimited(&self) -> usize
fn encoded_len_with_length_delimited(&self) -> usize
Returns the encoded length of the data including the length delimited.
Source§fn encode_to_vec(&self) -> Result<Vec<u8>, EncodeError>
fn encode_to_vec(&self) -> Result<Vec<u8>, EncodeError>
Encodes the message into a vec.
Source§fn encode_to_bytes(&self) -> Result<Bytes, EncodeError>
fn encode_to_bytes(&self) -> Result<Bytes, EncodeError>
Encodes the message into a
Bytes
.Source§fn encode_length_delimited(&self, buf: &mut [u8]) -> Result<usize, EncodeError>
fn encode_length_delimited(&self, buf: &mut [u8]) -> Result<usize, EncodeError>
Encodes the message with a length-delimiter to a buffer. Read more
Source§fn encode_length_delimited_to_vec(&self) -> Result<Vec<u8>, EncodeError>
fn encode_length_delimited_to_vec(&self) -> Result<Vec<u8>, EncodeError>
Encodes the message with a length-delimiter into a vec.
Source§fn encode_length_delimited_to_bytes(&self) -> Result<Bytes, EncodeError>
fn encode_length_delimited_to_bytes(&self) -> Result<Bytes, EncodeError>
Encodes the message with a length-delimiter into a
Bytes
.Source§fn decode(src: &[u8]) -> Result<(usize, Self), DecodeError>where
Self: Sized,
fn decode(src: &[u8]) -> Result<(usize, Self), DecodeError>where
Self: Sized,
Decodes an instance of the message from a buffer. Read more
Source§fn decode_length_delimited(buf: &[u8]) -> Result<(usize, Self), DecodeError>where
Self: Sized,
fn decode_length_delimited(buf: &[u8]) -> Result<(usize, Self), DecodeError>where
Self: Sized,
Decodes a length-delimited instance of the message from the buffer.
Source§impl<'a, I, A> DataRef<'a, Node<I, A>> for Node<<I as Data>::Ref<'a>, <A as Data>::Ref<'a>>
impl<'a, I, A> DataRef<'a, Node<I, A>> for Node<<I as Data>::Ref<'a>, <A as Data>::Ref<'a>>
Source§fn decode(
src: &'a [u8],
) -> Result<(usize, Node<<I as Data>::Ref<'a>, <A as Data>::Ref<'a>>), DecodeError>
fn decode( src: &'a [u8], ) -> Result<(usize, Node<<I as Data>::Ref<'a>, <A as Data>::Ref<'a>>), DecodeError>
Decodes the reference type from a buffer. Read more
Source§fn decode_length_delimited(src: &'a [u8]) -> Result<(usize, Self), DecodeError>where
Self: Sized,
fn decode_length_delimited(src: &'a [u8]) -> Result<(usize, Self), DecodeError>where
Self: Sized,
Decodes a length-delimited reference instance of the message from the buffer.
Source§impl<'de, I, A> Deserialize<'de> for Node<I, A>where
I: Deserialize<'de>,
A: Deserialize<'de>,
impl<'de, I, A> Deserialize<'de> for Node<I, A>where
I: Deserialize<'de>,
A: Deserialize<'de>,
Source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<Node<I, A>, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<Node<I, A>, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl<I, A> Ord for Node<I, A>
impl<I, A> Ord for Node<I, A>
1.21.0 · Source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
Compares and returns the maximum of two values. Read more
Source§impl<I, A> PartialOrd for Node<I, A>where
I: PartialOrd,
A: PartialOrd,
impl<I, A> PartialOrd for Node<I, A>where
I: PartialOrd,
A: PartialOrd,
Source§impl<I, A> Serialize for Node<I, A>
impl<I, A> Serialize for Node<I, A>
Source§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
Serialize this value into the given Serde serializer. Read more
impl<I, A> Copy for Node<I, A>
impl<I, A> Eq for Node<I, A>
impl<I, A> StructuralPartialEq for Node<I, A>
Auto Trait Implementations§
impl<I, A> Freeze for Node<I, A>
impl<I, A> RefUnwindSafe for Node<I, A>where
I: RefUnwindSafe,
A: RefUnwindSafe,
impl<I, A> Send for Node<I, A>
impl<I, A> Sync for Node<I, A>
impl<I, A> Unpin for Node<I, A>
impl<I, A> UnwindSafe for Node<I, A>where
I: UnwindSafe,
A: 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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Comparable<K> for Q
impl<Q, K> Comparable<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§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