Anonymous function to avoid type issues

new-scheduler
razican 5 years ago
parent 79bbf4938d
commit 0c37d4af10
No known key found for this signature in database
GPG Key ID: 76E895FB1EDE827C

@ -5,6 +5,7 @@ use pin_project_lite::pin_project;
use crate::prelude::*; use crate::prelude::*;
use crate::stream::Fuse; use crate::stream::Fuse;
use crate::utils;
pin_project! { pin_project! {
/// A stream that merges two other streams into a single stream. /// A stream that merges two other streams into a single stream.
@ -43,11 +44,20 @@ where
fn poll_next(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Option<Self::Item>> { fn poll_next(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Option<Self::Item>> {
let this = self.project(); let this = self.project();
let (first, second) = if (utils::random(1) == 1) { if utils::random(1) == 1 {
(this.left, this.right) poll_next_in_order(cx, this.left, this.right)
} else { } else {
(this.right, this.left) poll_next_in_order(cx, this.right, this.left)
}; }
}
}
/// Pools the next item, trying in order, first the first item, then the second one.
fn poll_next_in_order<F, S, T>(cx: &mut Context<'_>, first: F, second: S) -> Poll<Option<T>>
where
F: Stream<Item = T>,
S: Stream<Item = T>,
{
match first.poll_next(cx) { match first.poll_next(cx) {
Poll::Ready(Some(item)) => Poll::Ready(Some(item)), Poll::Ready(Some(item)) => Poll::Ready(Some(item)),
Poll::Ready(None) => second.poll_next(cx), Poll::Ready(None) => second.poll_next(cx),
@ -57,5 +67,4 @@ where
Poll::Pending => Poll::Pending, Poll::Pending => Poll::Pending,
}, },
} }
}
} }

Loading…
Cancel
Save