Struct Fanout

Source
pub struct Fanout<A, B>
where A: Sink, B: Sink,
{ /* private fields */ }
Expand description

Sink that clones incoming items and forwards them to two sinks at the same time.

Backpressure from any downstream sink propagates up, which means that this sink can only process items as fast as its slowest downstream sink.

Implementations§

Source§

impl<A, B> Fanout<A, B>
where A: Sink, B: Sink,

Source

pub fn into_inner(self) -> (A, B)

Consumes this combinator, returning the underlying sinks.

Note that this may discard intermediate state of this combinator, so care should be taken to avoid losing resources when this is called.

Trait Implementations§

Source§

impl<A, B> Debug for Fanout<A, B>
where A: Sink + Debug, B: Sink + Debug, <A as Sink>::SinkItem: Debug, <B as Sink>::SinkItem: Debug,

Source§

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

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

impl<A, B> Sink for Fanout<A, B>
where A: Sink, <A as Sink>::SinkItem: Clone, B: Sink<SinkItem = <A as Sink>::SinkItem, SinkError = <A as Sink>::SinkError>,

Source§

type SinkItem = <A as Sink>::SinkItem

The type of value that the sink accepts.
Source§

type SinkError = <A as Sink>::SinkError

The type of value produced by the sink when an error occurs.
Source§

fn start_send( &mut self, item: <Fanout<A, B> as Sink>::SinkItem, ) -> Result<AsyncSink<<Fanout<A, B> as Sink>::SinkItem>, <Fanout<A, B> as Sink>::SinkError>

Begin the process of sending a value to the sink. Read more
Source§

fn poll_complete( &mut self, ) -> Result<Async<()>, <Fanout<A, B> as Sink>::SinkError>

Flush all output from this sink, if necessary. Read more
Source§

fn close(&mut self) -> Result<Async<()>, <Fanout<A, B> as Sink>::SinkError>

A method to indicate that no more values will ever be pushed into this sink. Read more
Source§

fn wait(self) -> Wait<Self>
where Self: Sized,

Creates a new object which will produce a synchronous sink. Read more
Source§

fn with<U, F, Fut>(self, f: F) -> With<Self, U, F, Fut>
where F: FnMut(U) -> Fut, Fut: IntoFuture<Item = Self::SinkItem>, <Fut as IntoFuture>::Error: From<Self::SinkError>, Self: Sized,

Composes a function in front of the sink. Read more
Source§

fn with_flat_map<U, F, St>(self, f: F) -> WithFlatMap<Self, U, F, St>
where F: FnMut(U) -> St, St: Stream<Item = Self::SinkItem, Error = Self::SinkError>, Self: Sized,

Composes a function in front of the sink. Read more
Source§

fn sink_map_err<F, E>(self, f: F) -> SinkMapErr<Self, F>
where F: FnOnce(Self::SinkError) -> E, Self: Sized,

Transforms the error returned by the sink.
Source§

fn sink_from_err<E>(self) -> SinkFromErr<Self, E>
where E: From<Self::SinkError>, Self: Sized,

Map this sink’s error to any error implementing From for this sink’s Error, returning a new sink. Read more
Source§

fn buffer(self, amt: usize) -> Buffer<Self>
where Self: Sized,

Adds a fixed-size buffer to the current sink. Read more
Source§

fn fanout<S>(self, other: S) -> Fanout<Self, S>
where Self: Sized, Self::SinkItem: Clone, S: Sink<SinkItem = Self::SinkItem, SinkError = Self::SinkError>,

Fanout items to multiple sinks. Read more
Source§

fn flush(self) -> Flush<Self>
where Self: Sized,

A future that completes when the sink has finished processing all pending requests. Read more
Source§

fn send(self, item: Self::SinkItem) -> Send<Self>
where Self: Sized,

A future that completes after the given item has been fully processed into the sink, including flushing. Read more
Source§

fn send_all<S>(self, stream: S) -> SendAll<Self, S>
where S: Stream<Item = Self::SinkItem>, Self::SinkError: From<<S as Stream>::Error>, Self: Sized,

A future that completes after the given stream has been fully processed into the sink, including flushing. Read more

Auto Trait Implementations§

§

impl<A, B> Freeze for Fanout<A, B>
where A: Freeze, B: Freeze, <A as Sink>::SinkItem: Freeze, <B as Sink>::SinkItem: Freeze,

§

impl<A, B> RefUnwindSafe for Fanout<A, B>

§

impl<A, B> Send for Fanout<A, B>
where A: Send, B: Send, <A as Sink>::SinkItem: Send, <B as Sink>::SinkItem: Send,

§

impl<A, B> Sync for Fanout<A, B>
where A: Sync, B: Sync, <A as Sink>::SinkItem: Sync, <B as Sink>::SinkItem: Sync,

§

impl<A, B> Unpin for Fanout<A, B>
where A: Unpin, B: Unpin, <A as Sink>::SinkItem: Unpin, <B as Sink>::SinkItem: Unpin,

§

impl<A, B> UnwindSafe for Fanout<A, B>

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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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