Struct futures_util::sink::Fanout[][src]

pub struct Fanout<Si1: Sink, Si2: Sink> { /* fields omitted */ }

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<Si1: Sink, Si2: Sink> Fanout<Si1, Si2>
[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<Si1: Sink + Debug, Si2: Sink + Debug> Debug for Fanout<Si1, Si2> where
    Si1::SinkItem: Debug,
    Si2::SinkItem: Debug
[src]

Formats the value using the given formatter. Read more

impl<Si1, Si2> Sink for Fanout<Si1, Si2> where
    Si1: Sink,
    Si1::SinkItem: Clone,
    Si2: Sink<SinkItem = Si1::SinkItem, SinkError = Si1::SinkError>, 
[src]

The type of value that the sink accepts.

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

Attempts to prepare the Sink to receive a value. Read more

Begin the process of sending a value to the sink. Each call to this function must be proceeded by a successful call to poll_ready which returned Ok(Poll::Ready(())). Read more

Flush any remaining output from this sink. Read more

Flush any remaining output and close this sink, if necessary. Read more

Auto Trait Implementations

impl<Si1, Si2> Send for Fanout<Si1, Si2> where
    Si1: Send,
    Si2: Send

impl<Si1, Si2> Sync for Fanout<Si1, Si2> where
    Si1: Sync,
    Si2: Sync