[−][src]Struct futures::sink::Fanout
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.
Methods
impl<A: Sink, B: Sink> Fanout<A, B>
[src]
pub fn into_inner(self) -> (A, B)
[src]
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
impl<A, B> Sink for Fanout<A, B> where
A: Sink,
A::SinkItem: Clone,
B: Sink<SinkItem = A::SinkItem, SinkError = A::SinkError>,
[src]
A: Sink,
A::SinkItem: Clone,
B: Sink<SinkItem = A::SinkItem, SinkError = A::SinkError>,
type SinkItem = A::SinkItem
The type of value that the sink accepts.
type SinkError = A::SinkError
The type of value produced by the sink when an error occurs.
fn start_send(
&mut self,
item: Self::SinkItem
) -> StartSend<Self::SinkItem, Self::SinkError>
[src]
&mut self,
item: Self::SinkItem
) -> StartSend<Self::SinkItem, Self::SinkError>
fn poll_complete(&mut self) -> Poll<(), Self::SinkError>
[src]
fn close(&mut self) -> Poll<(), Self::SinkError>
[src]
fn wait(self) -> Wait<Self> where
Self: Sized,
[src]
Self: Sized,
Creates a new object which will produce a synchronous sink. Read more
fn with<U, F, Fut>(self, f: F) -> With<Self, U, F, Fut> where
F: FnMut(U) -> Fut,
Fut: IntoFuture<Item = Self::SinkItem>,
Fut::Error: From<Self::SinkError>,
Self: Sized,
[src]
F: FnMut(U) -> Fut,
Fut: IntoFuture<Item = Self::SinkItem>,
Fut::Error: From<Self::SinkError>,
Self: Sized,
Composes a function in front of the sink. Read more
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,
[src]
F: FnMut(U) -> St,
St: Stream<Item = Self::SinkItem, Error = Self::SinkError>,
Self: Sized,
Composes a function in front of the sink. Read more
fn sink_map_err<F, E>(self, f: F) -> SinkMapErr<Self, F> where
F: FnOnce(Self::SinkError) -> E,
Self: Sized,
[src]
F: FnOnce(Self::SinkError) -> E,
Self: Sized,
Transforms the error returned by the sink.
fn sink_from_err<E: From<Self::SinkError>>(self) -> SinkFromErr<Self, E> where
Self: Sized,
[src]
Self: Sized,
Map this sink's error to any error implementing From
for this sink's Error
, returning a new sink. Read more
fn buffer(self, amt: usize) -> Buffer<Self> where
Self: Sized,
[src]
Self: Sized,
Adds a fixed-size buffer to the current sink. Read more
fn fanout<S>(self, other: S) -> Fanout<Self, S> where
Self: Sized,
Self::SinkItem: Clone,
S: Sink<SinkItem = Self::SinkItem, SinkError = Self::SinkError>,
[src]
Self: Sized,
Self::SinkItem: Clone,
S: Sink<SinkItem = Self::SinkItem, SinkError = Self::SinkError>,
Fanout items to multiple sinks. Read more
fn flush(self) -> Flush<Self> where
Self: Sized,
[src]
Self: Sized,
A future that completes when the sink has finished processing all pending requests. Read more
fn send(self, item: Self::SinkItem) -> Send<Self> where
Self: Sized,
[src]
Self: Sized,
A future that completes after the given item has been fully processed into the sink, including flushing. Read more
fn send_all<S>(self, stream: S) -> SendAll<Self, S> where
S: Stream<Item = Self::SinkItem>,
Self::SinkError: From<S::Error>,
Self: Sized,
[src]
S: Stream<Item = Self::SinkItem>,
Self::SinkError: From<S::Error>,
Self: Sized,
A future that completes after the given stream has been fully processed into the sink, including flushing. Read more
impl<A: Sink + Debug, B: Sink + Debug> Debug for Fanout<A, B> where
A::SinkItem: Debug,
B::SinkItem: Debug,
[src]
A::SinkItem: Debug,
B::SinkItem: Debug,
Auto Trait Implementations
impl<A, B> Unpin for Fanout<A, B> where
A: Unpin,
B: Unpin,
<A as Sink>::SinkItem: Unpin,
<B as Sink>::SinkItem: Unpin,
A: Unpin,
B: Unpin,
<A as Sink>::SinkItem: Unpin,
<B as Sink>::SinkItem: Unpin,
impl<A, B> Send for Fanout<A, B> where
A: Send,
B: Send,
<A as Sink>::SinkItem: Send,
<B as Sink>::SinkItem: Send,
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,
A: Sync,
B: Sync,
<A as Sink>::SinkItem: Sync,
<B as Sink>::SinkItem: Sync,
impl<A, B> UnwindSafe for Fanout<A, B> where
A: UnwindSafe,
B: UnwindSafe,
<A as Sink>::SinkItem: UnwindSafe,
<B as Sink>::SinkItem: UnwindSafe,
A: UnwindSafe,
B: UnwindSafe,
<A as Sink>::SinkItem: UnwindSafe,
<B as Sink>::SinkItem: UnwindSafe,
impl<A, B> RefUnwindSafe for Fanout<A, B> where
A: RefUnwindSafe,
B: RefUnwindSafe,
<A as Sink>::SinkItem: RefUnwindSafe,
<B as Sink>::SinkItem: RefUnwindSafe,
A: RefUnwindSafe,
B: RefUnwindSafe,
<A as Sink>::SinkItem: RefUnwindSafe,
<B as Sink>::SinkItem: RefUnwindSafe,
Blanket Implementations
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> From<T> for T
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,