mirror of
https://github.com/async-rs/async-std.git
synced 2025-10-24 05:16:36 +00:00
Merge pull request #732 from hhggit/timeout_repeat
make StreamExt::timeout(d).next() behave like future::timeout(d, s.next())
This commit is contained in:
commit
415d0d1e51
1 changed files with 11 additions and 6 deletions
|
@ -18,6 +18,7 @@ pin_project! {
|
||||||
stream: S,
|
stream: S,
|
||||||
#[pin]
|
#[pin]
|
||||||
delay: Timer,
|
delay: Timer,
|
||||||
|
duration: Duration,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,7 +26,7 @@ impl<S: Stream> Timeout<S> {
|
||||||
pub(crate) fn new(stream: S, dur: Duration) -> Self {
|
pub(crate) fn new(stream: S, dur: Duration) -> Self {
|
||||||
let delay = timer_after(dur);
|
let delay = timer_after(dur);
|
||||||
|
|
||||||
Self { stream, delay }
|
Self { stream, delay, duration: dur }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -33,16 +34,20 @@ impl<S: Stream> Stream for Timeout<S> {
|
||||||
type Item = Result<S::Item, TimeoutError>;
|
type Item = Result<S::Item, TimeoutError>;
|
||||||
|
|
||||||
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 mut this = self.project();
|
||||||
|
|
||||||
match this.stream.poll_next(cx) {
|
let r = match this.stream.poll_next(cx) {
|
||||||
Poll::Ready(Some(v)) => Poll::Ready(Some(Ok(v))),
|
Poll::Ready(Some(v)) => Poll::Ready(Some(Ok(v))),
|
||||||
Poll::Ready(None) => Poll::Ready(None),
|
Poll::Ready(None) => Poll::Ready(None),
|
||||||
Poll::Pending => match this.delay.poll(cx) {
|
Poll::Pending => match this.delay.as_mut().poll(cx) {
|
||||||
Poll::Ready(_) => Poll::Ready(Some(Err(TimeoutError { _private: () }))),
|
Poll::Ready(_) => Poll::Ready(Some(Err(TimeoutError { _private: () }))),
|
||||||
Poll::Pending => Poll::Pending,
|
Poll::Pending => return Poll::Pending,
|
||||||
},
|
},
|
||||||
}
|
};
|
||||||
|
|
||||||
|
*this.delay.as_mut() = timer_after(*this.duration);
|
||||||
|
|
||||||
|
r
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue