mirror of
				https://github.com/async-rs/async-std.git
				synced 2025-10-24 21:36:37 +00:00 
			
		
		
		
	reset timer after timeout was ready
This commit is contained in:
		
							parent
							
								
									73035006dc
								
							
						
					
					
						commit
						3bb121dc1e
					
				
					 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