mirror of
				https://github.com/rust-lang/rust.git
				synced 2025-10-30 20:44:34 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			179 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			179 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
| //@ run-pass
 | |
| #![allow(unused_must_use)]
 | |
| fn main() {
 | |
|     if false { test(); }
 | |
| }
 | |
| 
 | |
| fn test() {
 | |
|     let rx = Err::<Vec<usize>, u32>(1).into_future();
 | |
| 
 | |
|     rx.map(|l: Vec<usize>| stream::iter(l.into_iter().map(|i| Ok(i))))
 | |
|       .flatten_stream()
 | |
|       .chunks(50)
 | |
|       .buffer_unordered(5);
 | |
| }
 | |
| 
 | |
| use future::{Future, IntoFuture};
 | |
| mod future {
 | |
|     use std::result;
 | |
| 
 | |
|     use crate::{stream, Stream};
 | |
| 
 | |
|     pub trait Future {
 | |
|         type Item;
 | |
|         type Error;
 | |
| 
 | |
|         fn map<F, U>(self, _: F) -> Map<Self, F>
 | |
|             where F: FnOnce(Self::Item) -> U,
 | |
|                   Self: Sized,
 | |
|         {
 | |
|             panic!()
 | |
|         }
 | |
| 
 | |
|         fn flatten_stream(self) -> FlattenStream<Self>
 | |
|             where <Self as Future>::Item: stream::Stream<Error=Self::Error>,
 | |
|                   Self: Sized
 | |
|         {
 | |
|             panic!()
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     pub trait IntoFuture {
 | |
|         type Future: Future<Item=Self::Item, Error=Self::Error>;
 | |
|         type Item;
 | |
|         type Error;
 | |
|         fn into_future(self) -> Self::Future;
 | |
|     }
 | |
| 
 | |
|     impl<F: Future> IntoFuture for F {
 | |
|         type Future = F;
 | |
|         type Item = F::Item;
 | |
|         type Error = F::Error;
 | |
| 
 | |
|         fn into_future(self) -> F {
 | |
|             panic!()
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     impl<T, E> IntoFuture for result::Result<T, E> {
 | |
|         type Future = FutureResult<T, E>;
 | |
|         type Item = T;
 | |
|         type Error = E;
 | |
| 
 | |
|         fn into_future(self) -> FutureResult<T, E> {
 | |
|             panic!()
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     pub struct Map<A, F> {
 | |
|         _a: (A, F),
 | |
|     }
 | |
| 
 | |
|     impl<U, A, F> Future for Map<A, F>
 | |
|         where A: Future,
 | |
|               F: FnOnce(A::Item) -> U,
 | |
|     {
 | |
|         type Item = U;
 | |
|         type Error = A::Error;
 | |
|     }
 | |
| 
 | |
|     pub struct FlattenStream<F> {
 | |
|         _f: F,
 | |
|     }
 | |
| 
 | |
|     impl<F> Stream for FlattenStream<F>
 | |
|         where F: Future,
 | |
|               <F as Future>::Item: Stream<Error=F::Error>,
 | |
|     {
 | |
|         type Item = <F::Item as Stream>::Item;
 | |
|         type Error = <F::Item as Stream>::Error;
 | |
|     }
 | |
| 
 | |
|     pub struct FutureResult<T, E> {
 | |
|         _inner: (T, E),
 | |
|     }
 | |
| 
 | |
|     impl<T, E> Future for FutureResult<T, E> {
 | |
|         type Item = T;
 | |
|         type Error = E;
 | |
|     }
 | |
| }
 | |
| 
 | |
| mod stream {
 | |
|     use crate::IntoFuture;
 | |
| 
 | |
|     pub trait Stream {
 | |
|         type Item;
 | |
|         type Error;
 | |
| 
 | |
|         fn buffer_unordered(self, amt: usize) -> BufferUnordered<Self>
 | |
|             where Self::Item: IntoFuture<Error = <Self as Stream>::Error>,
 | |
|                   Self: Sized
 | |
|         {
 | |
|             new(self, amt)
 | |
|         }
 | |
| 
 | |
|         fn chunks(self, _capacity: usize) -> Chunks<Self>
 | |
|             where Self: Sized
 | |
|         {
 | |
|             panic!()
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     pub struct IterStream<I> {
 | |
|         _iter: I,
 | |
|     }
 | |
| 
 | |
|     pub fn iter<J, T, E>(_: J) -> IterStream<J::IntoIter>
 | |
|         where J: IntoIterator<Item=Result<T, E>>,
 | |
|     {
 | |
|         panic!()
 | |
|     }
 | |
| 
 | |
|     impl<I, T, E> Stream for IterStream<I>
 | |
|         where I: Iterator<Item=Result<T, E>>,
 | |
|     {
 | |
|         type Item = T;
 | |
|         type Error = E;
 | |
|     }
 | |
| 
 | |
|     pub struct Chunks<S> {
 | |
|         _stream: S
 | |
|     }
 | |
| 
 | |
|     impl<S> Stream for Chunks<S>
 | |
|         where S: Stream
 | |
|     {
 | |
|         type Item = Result<Vec<<S as Stream>::Item>, u32>;
 | |
|         type Error = <S as Stream>::Error;
 | |
|     }
 | |
| 
 | |
|     pub struct BufferUnordered<S> {
 | |
|         _stream: S,
 | |
|     }
 | |
| 
 | |
|     enum Slot<T> {
 | |
|         Next(#[allow(dead_code)] usize),
 | |
|         _Data { _a: T },
 | |
|     }
 | |
| 
 | |
|     fn new<S>(_s: S, _amt: usize) -> BufferUnordered<S>
 | |
|         where S: Stream,
 | |
|               S::Item: IntoFuture<Error=<S as Stream>::Error>,
 | |
|     {
 | |
|         (0..0).map(|_| {
 | |
|             Slot::Next::<<S::Item as IntoFuture>::Future>(1)
 | |
|         }).collect::<Vec<_>>();
 | |
|         panic!()
 | |
|     }
 | |
| 
 | |
|     impl<S> Stream for BufferUnordered<S>
 | |
|         where S: Stream,
 | |
|               S::Item: IntoFuture<Error=<S as Stream>::Error>,
 | |
|     {
 | |
|         type Item = <S::Item as IntoFuture>::Item;
 | |
|         type Error = <S as Stream>::Error;
 | |
|     }
 | |
| }
 | |
| use stream::Stream;
 | 
