Struct libp2p_swarm::handler::multi::MultiHandler

source ·
pub struct MultiHandler<K, H> { /* private fields */ }
Expand description

A ConnectionHandler for multiple ConnectionHandlers of the same type.

Implementations§

source§

impl<K, H> MultiHandler<K, H>
where K: Clone + Debug + Hash + Eq + Send + 'static, H: ConnectionHandler,

source

pub fn try_from_iter<I>(iter: I) -> Result<Self, DuplicateProtonameError>
where I: IntoIterator<Item = (K, H)>,

Create and populate a MultiHandler from the given handler iterator.

It is an error for any two protocols handlers to share the same protocol name.

Trait Implementations§

source§

impl<K: Clone, H: Clone> Clone for MultiHandler<K, H>

source§

fn clone(&self) -> MultiHandler<K, H>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<K, H> ConnectionHandler for MultiHandler<K, H>

§

type InEvent = (K, <H as ConnectionHandler>::InEvent)

Custom event that can be received from the outside.
§

type OutEvent = (K, <H as ConnectionHandler>::OutEvent)

Custom event that can be produced by the handler and that will be returned to the outside.
§

type Error = <H as ConnectionHandler>::Error

The type of errors returned by ConnectionHandler::poll.
§

type InboundProtocol = Upgrade<K, <H as ConnectionHandler>::InboundProtocol>

The inbound upgrade for the protocol(s) used by the handler.
§

type OutboundProtocol = <H as ConnectionHandler>::OutboundProtocol

The outbound upgrade for the protocol(s) used by the handler.
§

type InboundOpenInfo = Info<K, <H as ConnectionHandler>::InboundOpenInfo>

The type of additional information returned from listen_protocol.
§

type OutboundOpenInfo = (K, <H as ConnectionHandler>::OutboundOpenInfo)

The type of additional information passed to an OutboundSubstreamRequest.
source§

fn listen_protocol( &self, ) -> SubstreamProtocol<Self::InboundProtocol, Self::InboundOpenInfo>

The InboundUpgrade to apply on inbound substreams to negotiate the desired protocols. Read more
source§

fn on_connection_event( &mut self, event: ConnectionEvent<'_, Self::InboundProtocol, Self::OutboundProtocol, Self::InboundOpenInfo, Self::OutboundOpenInfo>, )

source§

fn on_behaviour_event(&mut self, (key, event): Self::InEvent)

Informs the handler about an event from the NetworkBehaviour.
source§

fn connection_keep_alive(&self) -> KeepAlive

Returns until when the connection should be kept alive. Read more
source§

fn poll( &mut self, cx: &mut Context<'_>, ) -> Poll<ConnectionHandlerEvent<Self::OutboundProtocol, Self::OutboundOpenInfo, Self::OutEvent, Self::Error>>

Should behave like Stream::poll().
source§

fn map_in_event<TNewIn, TMap>(self, map: TMap) -> MapInEvent<Self, TNewIn, TMap>
where Self: Sized, TMap: Fn(&TNewIn) -> Option<&Self::InEvent>,

Adds a closure that turns the input event into something else.
source§

fn map_out_event<TMap, TNewOut>(self, map: TMap) -> MapOutEvent<Self, TMap>
where Self: Sized, TMap: FnMut(Self::OutEvent) -> TNewOut,

Adds a closure that turns the output event into something else.
source§

fn select<TProto2>( self, other: TProto2, ) -> ConnectionHandlerSelect<Self, TProto2>
where Self: Sized,

Creates a new ConnectionHandler that selects either this handler or other by delegating methods calls appropriately. Read more
source§

impl<K, H> Debug for MultiHandler<K, H>
where K: Debug + Eq + Hash, H: Debug,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<K, H> IntoIterator for MultiHandler<K, H>

Split MultiHandler into parts.

§

type Item = <<MultiHandler<K, H> as IntoIterator>::IntoIter as Iterator>::Item

The type of the elements being iterated over.
§

type IntoIter = IntoIter<K, H>

Which kind of iterator are we turning this into?
source§

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more

Auto Trait Implementations§

§

impl<K, H> Freeze for MultiHandler<K, H>

§

impl<K, H> RefUnwindSafe for MultiHandler<K, H>

§

impl<K, H> Send for MultiHandler<K, H>
where K: Send, H: Send,

§

impl<K, H> Sync for MultiHandler<K, H>
where K: Sync, H: Sync,

§

impl<K, H> Unpin for MultiHandler<K, H>
where K: Unpin, H: Unpin,

§

impl<K, H> UnwindSafe for MultiHandler<K, H>
where K: UnwindSafe, H: UnwindSafe,

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> 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<T> CloneToUninit for T
where T: Clone,

source§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
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> IntoConnectionHandler for T

§

type Handler = T

👎Deprecated: Implement ConnectionHandler directly and use NetworkBehaviour::{handle_pending_inbound_connection,handle_pending_outbound_connection} to handle pending connections.
The protocols handler.
source§

fn into_handler(self, _: &PeerId, _: &ConnectedPoint) -> T

👎Deprecated: Implement ConnectionHandler directly and use NetworkBehaviour::{handle_pending_inbound_connection,handle_pending_outbound_connection} to handle pending connections.
Builds the protocols handler. Read more
source§

fn inbound_protocol( &self, ) -> <<T as IntoConnectionHandler>::Handler as ConnectionHandler>::InboundProtocol

👎Deprecated: Implement ConnectionHandler directly and use NetworkBehaviour::{handle_pending_inbound_connection,handle_pending_outbound_connection} to handle pending connections.
Return the handler’s inbound protocol.
source§

fn select<TProto2>( self, other: TProto2, ) -> IntoConnectionHandlerSelect<Self, TProto2>
where Self: Sized,

👎Deprecated: Implement ConnectionHandler directly and use NetworkBehaviour::{handle_pending_inbound_connection,handle_pending_outbound_connection} to handle pending connections.
Builds an implementation of IntoConnectionHandler that handles both this protocol and the other one together.
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

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

§

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

§

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