Struct CompositeDelegate

Source
pub struct CompositeDelegate<I, A, M = DefaultMergeDelegate<I, A>, R = NoopReconnectDelegate<I, A>, T = LpeTransfromDelegate<I, A>> { /* private fields */ }
Expand description

CompositeDelegate is a helpful struct to split the Delegate into multiple small delegates, so that users do not need to implement full Delegate when they only want to custom some methods in the Delegate.

Implementations§

Source§

impl<I, A> CompositeDelegate<I, A>

Source

pub fn new() -> Self

Returns a new CompositeDelegate.

Source§

impl<I, A, M, R, T> CompositeDelegate<I, A, M, R, T>
where M: MergeDelegate<Id = I, Address = A>,

Source

pub fn with_merge_delegate<NM>( self, merge: NM, ) -> CompositeDelegate<I, A, NM, R, T>

Set the MergeDelegate for the CompositeDelegate.

Source§

impl<I, A, M, R, T> CompositeDelegate<I, A, M, R, T>

Source

pub fn with_reconnect_delegate<NR>( self, reconnect: NR, ) -> CompositeDelegate<I, A, M, NR, T>

Set the ReconnectDelegate for the CompositeDelegate.

Source§

impl<I, A, M, R, T> CompositeDelegate<I, A, M, R, T>

Source

pub fn with_transform_delegate<NT>( self, transform: NT, ) -> CompositeDelegate<I, A, M, R, NT>

Set the TransformDelegate for the CompositeDelegate.

Trait Implementations§

Source§

impl<I, A> Default for CompositeDelegate<I, A>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<I, A, M, R, T> Delegate for CompositeDelegate<I, A, M, R, T>
where I: Id, A: CheapClone + Send + Sync + 'static, M: MergeDelegate<Id = I, Address = A>, R: ReconnectDelegate<Id = I, Address = A>, T: TransformDelegate<Id = I, Address = A>,

Source§

type Id = I

The id type of the delegate
Source§

type Address = A

The address type of the delegate
Source§

impl<I, A, M, R, T> MergeDelegate for CompositeDelegate<I, A, M, R, T>
where I: Id, A: CheapClone + Send + Sync + 'static, M: MergeDelegate<Id = I, Address = A>, R: Send + Sync + 'static, T: Send + Sync + 'static,

Source§

type Error = <M as MergeDelegate>::Error

The error type of the delegate
Source§

type Id = <M as MergeDelegate>::Id

The id type of the delegate
Source§

type Address = <M as MergeDelegate>::Address

The address type of the delegate
Source§

async fn notify_merge( &self, members: TinyVec<Member<Self::Id, Self::Address>>, ) -> Result<(), Self::Error>

Invoked when a merge could take place. Provides a list of the nodes known by the peer. If the return value is Err, the merge is canceled.
Source§

impl<I, A, M, R, T> ReconnectDelegate for CompositeDelegate<I, A, M, R, T>
where I: Id, A: CheapClone + Send + Sync + 'static, M: Send + Sync + 'static, R: ReconnectDelegate<Id = I, Address = A>, T: Send + Sync + 'static,

Source§

type Id = <R as ReconnectDelegate>::Id

The id type of the delegate
Source§

type Address = <R as ReconnectDelegate>::Address

The address type of the delegate
Source§

fn reconnect_timeout( &self, member: &Member<Self::Id, Self::Address>, timeout: Duration, ) -> Duration

Returns the reconnect timeout for the given member.
Source§

impl<I, A, M, R, T> TransformDelegate for CompositeDelegate<I, A, M, R, T>
where I: Id, A: CheapClone + Send + Sync + 'static, M: Send + Sync + 'static, R: Send + Sync + 'static, T: TransformDelegate<Id = I, Address = A>,

Source§

type Error = <T as TransformDelegate>::Error

The error type for the transformation.
Source§

type Id = <T as TransformDelegate>::Id

The Id type.
Source§

type Address = <T as TransformDelegate>::Address

The Address type.
Source§

fn encode_filter(filter: &Filter<Self::Id>) -> Result<Bytes, Self::Error>

Encodes the filter into bytes.
Source§

fn decode_filter(bytes: &[u8]) -> Result<(usize, Filter<Self::Id>), Self::Error>

Decodes the filter from the given bytes, returning the number of bytes consumed and the filter.
Source§

fn node_encoded_len(node: &Node<Self::Id, Self::Address>) -> usize

Returns the encoded length of the node.
Source§

fn encode_node( node: &Node<Self::Id, Self::Address>, dst: &mut [u8], ) -> Result<usize, Self::Error>

Encodes the node into the given buffer, returning the number of bytes written.
Source§

fn decode_node( bytes: impl AsRef<[u8]>, ) -> Result<(usize, Node<Self::Id, Self::Address>), Self::Error>

Decodes Node from the given bytes, returning the number of bytes consumed and the node.
Source§

fn id_encoded_len(id: &Self::Id) -> usize

Returns the encoded length of the id.
Source§

fn encode_id(id: &Self::Id, dst: &mut [u8]) -> Result<usize, Self::Error>

Encodes the id into the given buffer, returning the number of bytes written.
Source§

fn decode_id(bytes: &[u8]) -> Result<(usize, Self::Id), Self::Error>

Decodes the id from the given bytes, returning the number of bytes consumed and the id.
Source§

fn address_encoded_len(address: &Self::Address) -> usize

Returns the encoded length of the address.
Source§

fn encode_address( address: &Self::Address, dst: &mut [u8], ) -> Result<usize, Self::Error>

Encodes the address into the given buffer, returning the number of bytes written.
Source§

fn decode_address(bytes: &[u8]) -> Result<(usize, Self::Address), Self::Error>

Decodes the address from the given bytes, returning the number of bytes consumed and the address.
Source§

fn coordinate_encoded_len(coordinate: &Coordinate) -> usize

Encoded length of the coordinate.
Source§

fn encode_coordinate( coordinate: &Coordinate, dst: &mut [u8], ) -> Result<usize, Self::Error>

Encodes the coordinate into the given buffer, returning the number of bytes written.
Source§

fn decode_coordinate(bytes: &[u8]) -> Result<(usize, Coordinate), Self::Error>

Decodes the coordinate from the given bytes, returning the number of bytes consumed and the coordinate.
Source§

fn tags_encoded_len(tags: &Tags) -> usize

Encoded length of the tags.
Source§

fn encode_tags(tags: &Tags, dst: &mut [u8]) -> Result<usize, Self::Error>

Encodes the tags into the given buffer, returning the number of bytes written.
Source§

fn decode_tags(bytes: &[u8]) -> Result<(usize, Tags), Self::Error>

Decodes the tags from the given bytes, returning the number of bytes consumed and the tags.
Source§

fn message_encoded_len(msg: impl AsMessageRef<Self::Id, Self::Address>) -> usize

Encoded length of the message.
Source§

fn encode_message( msg: impl AsMessageRef<Self::Id, Self::Address>, dst: impl AsMut<[u8]>, ) -> Result<usize, Self::Error>

Encodes the message into the given buffer, returning the number of bytes written. Read more
Source§

fn decode_message( ty: MessageType, bytes: impl AsRef<[u8]>, ) -> Result<(usize, SerfMessage<Self::Id, Self::Address>), Self::Error>

Decodes the message from the given bytes, returning the number of bytes consumed and the message.

Auto Trait Implementations§

§

impl<I, A, M, R, T> Freeze for CompositeDelegate<I, A, M, R, T>
where M: Freeze, R: Freeze, T: Freeze,

§

impl<I, A, M, R, T> RefUnwindSafe for CompositeDelegate<I, A, M, R, T>

§

impl<I, A, M, R, T> Send for CompositeDelegate<I, A, M, R, T>
where M: Send, R: Send, T: Send, I: Send, A: Send,

§

impl<I, A, M, R, T> Sync for CompositeDelegate<I, A, M, R, T>
where M: Sync, R: Sync, T: Sync, I: Sync, A: Sync,

§

impl<I, A, M, R, T> Unpin for CompositeDelegate<I, A, M, R, T>
where M: Unpin, R: Unpin, T: Unpin, I: Unpin, A: Unpin,

§

impl<I, A, M, R, T> UnwindSafe for CompositeDelegate<I, A, M, R, T>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> ArchivePointee for T

Source§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
Source§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<K, Q> Comparable<Q> for K
where K: Borrow<Q> + ?Sized, Q: Ord + ?Sized,

Source§

fn compare(&self, key: &Q) -> Ordering

Compare self to key and return their ordering.
Source§

impl<K, Q> Equivalent<Q> for K
where K: Borrow<Q> + ?Sized, Q: Eq + ?Sized,

Source§

fn equivalent(&self, key: &Q) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Source§

impl<T> LayoutRaw for T

Source§

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
where T: SharedNiching<N1, N2>, N1: Niching<T>, N2: Niching<T>,

Source§

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>>)

Writes data to out indicating that a T is niched.
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Pointee for T

Source§

type Metadata = ()

The metadata type for pointers and references to this type.
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more