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 Self
pub fn set_address(&mut self, address: A) -> &mut Self
Set the address of the node.
Sourcepub fn with_address(self, address: A) -> Self
pub fn with_address(self, address: A) -> Self
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<'a, I: Arbitrary<'a>, A: Arbitrary<'a>> Arbitrary<'a> for Node<I, A>
impl<'a, I: Arbitrary<'a>, A: Arbitrary<'a>> Arbitrary<'a> for Node<I, A>
Source§fn arbitrary(u: &mut Unstructured<'a>) -> Result<Self>
fn arbitrary(u: &mut Unstructured<'a>) -> Result<Self>
Generate an arbitrary value of
Self
from the given unstructured data. Read moreSource§fn arbitrary_take_rest(u: Unstructured<'a>) -> Result<Self, Error>
fn arbitrary_take_rest(u: Unstructured<'a>) -> Result<Self, Error>
Generate an arbitrary value of
Self
from the entirety of the given
unstructured data. Read moreSource§fn size_hint(depth: usize) -> (usize, Option<usize>)
fn size_hint(depth: usize) -> (usize, Option<usize>)
Get a size hint for how many bytes out of an
Unstructured
this type
needs to construct itself. Read moreSource§fn try_size_hint(
depth: usize,
) -> Result<(usize, Option<usize>), MaxRecursionReached>
fn try_size_hint( depth: usize, ) -> Result<(usize, Option<usize>), MaxRecursionReached>
Get a size hint for how many bytes out of an
Unstructured
this type
needs to construct itself. Read moreSource§impl<I, A> Archive for Node<I, A>
impl<I, A> Archive for Node<I, A>
Source§type Archived = ArchivedNode<I, A>
type Archived = ArchivedNode<I, A>
The archived representation of this type. Read more
Source§type Resolver = NodeResolver<I, A>
type Resolver = NodeResolver<I, A>
The resolver for this type. It must contain all the additional
information from serializing needed to make the archived type from
the normal type.
Source§fn resolve(&self, resolver: Self::Resolver, out: Place<Self::Archived>)
fn resolve(&self, resolver: Self::Resolver, out: Place<Self::Archived>)
Creates the archived version of this value at the given position and
writes it to the given output. Read more
Source§const COPY_OPTIMIZATION: CopyOptimization<Self> = _
const COPY_OPTIMIZATION: CopyOptimization<Self> = _
An optimization flag that allows the bytes of this type to be copied
directly to a writer instead of calling
serialize
. Read moreSource§impl<I: CheapClone, A: CheapClone> CheapClone for Node<I, A>
impl<I: CheapClone, A: CheapClone> CheapClone for Node<I, A>
Source§fn cheap_clone(&self) -> Self
fn cheap_clone(&self) -> Self
Returns a copy of the value.
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<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<__D: Fallible + ?Sized, I, A> Deserialize<Node<I, A>, __D> for Archived<Node<I, A>>where
I: Archive,
<I as Archive>::Archived: Deserialize<I, __D>,
A: Archive,
<A as Archive>::Archived: Deserialize<A, __D>,
impl<__D: Fallible + ?Sized, I, A> Deserialize<Node<I, A>, __D> for Archived<Node<I, A>>where
I: Archive,
<I as Archive>::Archived: Deserialize<I, __D>,
A: Archive,
<A as Archive>::Archived: Deserialize<A, __D>,
Source§impl<I: Ord, A: Ord> Ord for Node<I, A>
impl<I: Ord, A: Ord> 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> PartialEq<ArchivedNode<I, A>> for Node<I, A>
impl<I, A> PartialEq<ArchivedNode<I, A>> for Node<I, A>
Source§impl<I, A> PartialEq<Node<I, A>> for ArchivedNode<I, A>
impl<I, A> PartialEq<Node<I, A>> for ArchivedNode<I, A>
Source§impl<I: PartialOrd, A: PartialOrd> PartialOrd for Node<I, A>
impl<I: PartialOrd, A: PartialOrd> PartialOrd for Node<I, A>
impl<I: Copy, A: Copy> Copy for Node<I, A>
impl<I: Eq, A: Eq> 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> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
Source§impl<T> ArchiveUnsized for Twhere
T: Archive,
impl<T> ArchiveUnsized for Twhere
T: Archive,
Source§type Archived = <T as Archive>::Archived
type Archived = <T as Archive>::Archived
The archived counterpart of this type. Unlike
Archive
, it may be
unsized. Read moreSource§fn archived_metadata(
&self,
) -> <<T as ArchiveUnsized>::Archived as ArchivePointee>::ArchivedMetadata
fn archived_metadata( &self, ) -> <<T as ArchiveUnsized>::Archived as ArchivePointee>::ArchivedMetadata
Creates the archived version of the metadata for this value.
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 moreSource§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out
indicating that a T
is niched.