forked from mirror/async-std
		
	fix: Remove Pin API related unsafe code
This commit is contained in:
		
							parent
							
								
									5c9cfb4fe8
								
							
						
					
					
						commit
						d97b3dfdf3
					
				
					 1 changed files with 13 additions and 9 deletions
				
			
		|  | @ -2,21 +2,23 @@ use std::pin::Pin; | ||||||
| use std::time::Duration; | use std::time::Duration; | ||||||
| 
 | 
 | ||||||
| use futures_timer::Delay; | use futures_timer::Delay; | ||||||
|  | use pin_project_lite::pin_project; | ||||||
| 
 | 
 | ||||||
| use crate::future::Future; | use crate::future::Future; | ||||||
| use crate::task::{Context, Poll}; | use crate::task::{Context, Poll}; | ||||||
| 
 | 
 | ||||||
|  | pin_project! { | ||||||
| #[doc(hidden)] | #[doc(hidden)] | ||||||
| #[derive(Debug)] | #[derive(Debug)] | ||||||
|     pub struct DelayFuture<F> { |     pub struct DelayFuture<F> { | ||||||
|  |         #[pin] | ||||||
|         future: F, |         future: F, | ||||||
|  |         #[pin] | ||||||
|         delay: Delay, |         delay: Delay, | ||||||
|     } |     } | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| impl<F> DelayFuture<F> { | impl<F> DelayFuture<F> { | ||||||
|     pin_utils::unsafe_pinned!(future: F); |  | ||||||
|     pin_utils::unsafe_pinned!(delay: Delay); |  | ||||||
| 
 |  | ||||||
|     pub fn new(future: F, dur: Duration) -> DelayFuture<F> { |     pub fn new(future: F, dur: Duration) -> DelayFuture<F> { | ||||||
|         let delay = Delay::new(dur); |         let delay = Delay::new(dur); | ||||||
| 
 | 
 | ||||||
|  | @ -27,10 +29,12 @@ impl<F> DelayFuture<F> { | ||||||
| impl<F: Future> Future for DelayFuture<F> { | impl<F: Future> Future for DelayFuture<F> { | ||||||
|     type Output = F::Output; |     type Output = F::Output; | ||||||
| 
 | 
 | ||||||
|     fn poll(mut self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output> { |     fn poll(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output> { | ||||||
|         match self.as_mut().delay().poll(cx) { |         let this = self.project(); | ||||||
|  | 
 | ||||||
|  |         match this.delay.poll(cx) { | ||||||
|             Poll::Pending => Poll::Pending, |             Poll::Pending => Poll::Pending, | ||||||
|             Poll::Ready(_) => match self.future().poll(cx) { |             Poll::Ready(_) => match this.future.poll(cx) { | ||||||
|                 Poll::Ready(v) => Poll::Ready(v), |                 Poll::Ready(v) => Poll::Ready(v), | ||||||
|                 Poll::Pending => Poll::Pending, |                 Poll::Pending => Poll::Pending, | ||||||
|             }, |             }, | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue