forked from mirror/async-std
		
	Fixed flatten
				
					
				
			This commit is contained in:
		
							parent
							
								
									85c32ef9d2
								
							
						
					
					
						commit
						32068942a6
					
				
					 3 changed files with 75 additions and 58 deletions
				
			
		|  | @ -1,5 +1,5 @@ | ||||||
| use std::fmt; | use core::fmt; | ||||||
| use std::pin::Pin; | use core::pin::Pin; | ||||||
| 
 | 
 | ||||||
| use pin_project_lite::pin_project; | use pin_project_lite::pin_project; | ||||||
| 
 | 
 | ||||||
|  | @ -52,14 +52,21 @@ where | ||||||
|         let mut this = self.project(); |         let mut this = self.project(); | ||||||
|         loop { |         loop { | ||||||
|             if let Some(inner) = this.inner_stream.as_mut().as_pin_mut() { |             if let Some(inner) = this.inner_stream.as_mut().as_pin_mut() { | ||||||
|                 if let item @ Some(_) = futures_core::ready!(inner.poll_next(cx)) { |                 let next_item = futures_core::ready!(inner.poll_next(cx)); | ||||||
|                     return Poll::Ready(item); | 
 | ||||||
|  |                 if next_item.is_some() { | ||||||
|  |                     return Poll::Ready(next_item); | ||||||
|  |                 } else { | ||||||
|  |                     this.inner_stream.set(None); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             match futures_core::ready!(this.stream.as_mut().poll_next(cx)) { |             let inner = futures_core::ready!(this.stream.as_mut().poll_next(cx)); | ||||||
|                 None => return Poll::Ready(None), | 
 | ||||||
|                 Some(inner) => this.inner_stream.set(Some(inner.into_stream())), |             if inner.is_some() { | ||||||
|  |                 this.inner_stream.set(inner.map(IntoStream::into_stream)); | ||||||
|  |             } else { | ||||||
|  |                 return Poll::Ready(None); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -1,3 +1,5 @@ | ||||||
|  | use std::convert::identity; | ||||||
|  | use std::marker::Unpin; | ||||||
| use std::pin::Pin; | use std::pin::Pin; | ||||||
| use std::task::{Context, Poll}; | use std::task::{Context, Poll}; | ||||||
| 
 | 
 | ||||||
|  | @ -99,15 +101,6 @@ fn merge_works_with_unfused_streams() { | ||||||
|     assert_eq!(xs, vec![92, 92]); |     assert_eq!(xs, vec![92, 92]); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #[test] |  | ||||||
| fn flat_map_doesnt_poll_completed_inner_stream() { |  | ||||||
|     async_std::task::block_on(async { |  | ||||||
|         use async_std::prelude::*; |  | ||||||
|         use async_std::task::*; |  | ||||||
|         use std::convert::identity; |  | ||||||
|         use std::marker::Unpin; |  | ||||||
|         use std::pin::Pin; |  | ||||||
| 
 |  | ||||||
| struct S<T>(T); | struct S<T>(T); | ||||||
| 
 | 
 | ||||||
| impl<T: Stream + Unpin> Stream for S<T> { | impl<T: Stream + Unpin> Stream for S<T> { | ||||||
|  | @ -120,7 +113,7 @@ fn flat_map_doesnt_poll_completed_inner_stream() { | ||||||
| 
 | 
 | ||||||
| struct StrictOnce { | struct StrictOnce { | ||||||
|     polled: bool, |     polled: bool, | ||||||
|         }; | } | ||||||
| 
 | 
 | ||||||
| impl Stream for StrictOnce { | impl Stream for StrictOnce { | ||||||
|     type Item = (); |     type Item = (); | ||||||
|  | @ -134,7 +127,7 @@ fn flat_map_doesnt_poll_completed_inner_stream() { | ||||||
| 
 | 
 | ||||||
| struct Interchanger { | struct Interchanger { | ||||||
|     polled: bool, |     polled: bool, | ||||||
|         }; | } | ||||||
| 
 | 
 | ||||||
| impl Stream for Interchanger { | impl Stream for Interchanger { | ||||||
|     type Item = S<Box<dyn Stream<Item = ()> + Unpin>>; |     type Item = S<Box<dyn Stream<Item = ()> + Unpin>>; | ||||||
|  | @ -151,6 +144,9 @@ fn flat_map_doesnt_poll_completed_inner_stream() { | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #[test] | ||||||
|  | fn flat_map_doesnt_poll_completed_inner_stream() { | ||||||
|  |     task::block_on(async { | ||||||
|         assert_eq!( |         assert_eq!( | ||||||
|             Interchanger { polled: false } |             Interchanger { polled: false } | ||||||
|                 .take(2) |                 .take(2) | ||||||
|  | @ -161,3 +157,17 @@ fn flat_map_doesnt_poll_completed_inner_stream() { | ||||||
|         ); |         ); | ||||||
|     }); |     }); | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | #[test] | ||||||
|  | fn flatten_doesnt_poll_completed_inner_stream() { | ||||||
|  |     task::block_on(async { | ||||||
|  |         assert_eq!( | ||||||
|  |             Interchanger { polled: false } | ||||||
|  |                 .take(2) | ||||||
|  |                 .flatten() | ||||||
|  |                 .count() | ||||||
|  |                 .await, | ||||||
|  |             0 | ||||||
|  |         ); | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue