Struct ordered_stream::FromStream [−][src]
pub struct FromStream<S, F, Ordering> { /* fields omitted */ }
Expand description
An OrderedStream
wrapper around a Stream
.
This caches the last-used ordering point returned by the stream and uses it to produce NoneBefore results. This makes it suitable for using to adapt streams that are filtered or mapped before joining. It still relies on the original stream producing a later-ordered element to allow other streams to progress, however.
Implementations
Create a new OrderedStream
by applying a split_item
closure to each element
produced by the original stream.
pub fn with_ordering(
stream: S,
get_ordering: F
) -> FromStream<S, impl FnMut(S::Item) -> (Ordering, S::Item), Ordering> where
F: FnMut(&S::Item) -> Ordering,
pub fn with_ordering(
stream: S,
get_ordering: F
) -> FromStream<S, impl FnMut(S::Item) -> (Ordering, S::Item), Ordering> where
F: FnMut(&S::Item) -> Ordering,
Helper function to simplify the creation of a stream when you have a get_ordering function.
Trait Implementations
impl<S, F, Ordering, Data> FusedOrderedStream for FromStream<S, F, Ordering> where
S: FusedStream,
F: FnMut(S::Item) -> (Ordering, Data),
Ordering: Ord + Clone,
impl<S, F, Ordering, Data> FusedOrderedStream for FromStream<S, F, Ordering> where
S: FusedStream,
F: FnMut(S::Item) -> (Ordering, Data),
Ordering: Ord + Clone,
Returns true
if the stream should no longer be polled.
impl<S, F, Ordering, Data> OrderedStream for FromStream<S, F, Ordering> where
S: Stream,
F: FnMut(S::Item) -> (Ordering, Data),
Ordering: Ord + Clone,
impl<S, F, Ordering, Data> OrderedStream for FromStream<S, F, Ordering> where
S: Stream,
F: FnMut(S::Item) -> (Ordering, Data),
Ordering: Ord + Clone,
fn poll_next_before(
self: Pin<&mut Self>,
cx: &mut Context<'_>,
before: Option<&Self::Ordering>
) -> Poll<PollResult<Ordering, Data>>
fn poll_next_before(
self: Pin<&mut Self>,
cx: &mut Context<'_>,
before: Option<&Self::Ordering>
) -> Poll<PollResult<Ordering, Data>>
Attempt to pull out the next value of this stream, registering the current task for wakeup
if needed, and returning NoneBefore
if it is known that the stream will not produce any
more values ordered before the given point. Read more