Remove Unpin bound from SelectAll
This commit is contained in:
		
							parent
							
								
									04a263c700
								
							
						
					
					
						commit
						e42295c4c5
					
				@ -1,11 +1,7 @@
 | 
				
			|||||||
#![allow(dead_code)]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
use core::future::Future;
 | 
					use core::future::Future;
 | 
				
			||||||
use core::pin::Pin;
 | 
					use core::pin::Pin;
 | 
				
			||||||
use core::task::{Context, Poll};
 | 
					use core::task::{Context, Poll};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
use futures::future::FutureExt;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/// Future for the [`select_all`] function.
 | 
					/// Future for the [`select_all`] function.
 | 
				
			||||||
#[derive(Debug)]
 | 
					#[derive(Debug)]
 | 
				
			||||||
#[must_use = "futures do nothing unless you `.await` or poll them"]
 | 
					#[must_use = "futures do nothing unless you `.await` or poll them"]
 | 
				
			||||||
@ -24,9 +20,9 @@ impl<Fut: Unpin, const N: usize> Unpin for SelectAll<Fut, N> {}
 | 
				
			|||||||
/// # Panics
 | 
					/// # Panics
 | 
				
			||||||
///
 | 
					///
 | 
				
			||||||
/// This function will panic if the array specified contains no items.
 | 
					/// This function will panic if the array specified contains no items.
 | 
				
			||||||
pub fn select_all<Fut: Future + Unpin, const N: usize>(arr: [Fut; N]) -> Option<SelectAll<Fut, N>> {
 | 
					pub fn select_all<Fut: Future, const N: usize>(arr: [Fut; N]) -> SelectAll<Fut, N> {
 | 
				
			||||||
    assert!(N > 0);
 | 
					    assert!(N > 0);
 | 
				
			||||||
    Some(SelectAll { inner: arr })
 | 
					    SelectAll { inner: arr }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
impl<Fut, const N: usize> SelectAll<Fut, N> {
 | 
					impl<Fut, const N: usize> SelectAll<Fut, N> {
 | 
				
			||||||
@ -36,18 +32,24 @@ impl<Fut, const N: usize> SelectAll<Fut, N> {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
impl<Fut: Future + Unpin, const N: usize> Future for SelectAll<Fut, N> {
 | 
					impl<Fut: Future, const N: usize> Future for SelectAll<Fut, N> {
 | 
				
			||||||
    type Output = (Fut::Output, usize);
 | 
					    type Output = (Fut::Output, usize);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    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> {
 | 
				
			||||||
        let item = self
 | 
					        // Safety: Since `self` is pinned, `inner` cannot move. Since `inner` cannot move,
 | 
				
			||||||
            .inner
 | 
					        // its elements also cannot move. Therefore it is safe to access `inner` and pin
 | 
				
			||||||
            .iter_mut()
 | 
					        // references to the contained futures.
 | 
				
			||||||
            .enumerate()
 | 
					        let item = unsafe {
 | 
				
			||||||
            .find_map(|(i, f)| match f.poll_unpin(cx) {
 | 
					            self.get_unchecked_mut()
 | 
				
			||||||
                Poll::Pending => None,
 | 
					                .inner
 | 
				
			||||||
                Poll::Ready(e) => Some((i, e)),
 | 
					                .iter_mut()
 | 
				
			||||||
            });
 | 
					                .enumerate()
 | 
				
			||||||
 | 
					                .find_map(|(i, f)| match Pin::new_unchecked(f).poll(cx) {
 | 
				
			||||||
 | 
					                    Poll::Pending => None,
 | 
				
			||||||
 | 
					                    Poll::Ready(e) => Some((i, e)),
 | 
				
			||||||
 | 
					                })
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        match item {
 | 
					        match item {
 | 
				
			||||||
            Some((idx, res)) => Poll::Ready((res, idx)),
 | 
					            Some((idx, res)) => Poll::Ready((res, idx)),
 | 
				
			||||||
            None => Poll::Pending,
 | 
					            None => Poll::Pending,
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user