diff options
Diffstat (limited to 'futures/src/stream.rs')
-rw-r--r-- | futures/src/stream.rs | 18 |
1 files changed, 6 insertions, 12 deletions
diff --git a/futures/src/stream.rs b/futures/src/stream.rs index 72e1f04b..ee9c0c14 100644 --- a/futures/src/stream.rs +++ b/futures/src/stream.rs @@ -8,13 +8,10 @@ use futures::stream::{self, Stream, StreamExt}; /// This is a more ergonomic [`stream::unfold`], which allows you to go /// from the "world of futures" to the "world of streams" by simply looping /// and publishing to an async channel from inside a [`Future`]. -pub fn channel<T, F>( +pub fn channel<T>( size: usize, - f: impl FnOnce(mpsc::Sender<T>) -> F, -) -> impl Stream<Item = T> -where - F: Future<Output = ()>, -{ + f: impl AsyncFnOnce(mpsc::Sender<T>), +) -> impl Stream<Item = T> { let (sender, receiver) = mpsc::channel(size); let runner = stream::once(f(sender)).filter_map(|_| async { None }); @@ -24,13 +21,10 @@ where /// Creates a new [`Stream`] that produces the items sent from a [`Future`] /// that can fail to the [`mpsc::Sender`] provided to the closure. -pub fn try_channel<T, E, F>( +pub fn try_channel<T, E>( size: usize, - f: impl FnOnce(mpsc::Sender<T>) -> F, -) -> impl Stream<Item = Result<T, E>> -where - F: Future<Output = Result<(), E>>, -{ + f: impl AsyncFnOnce(mpsc::Sender<T>) -> Result<(), E>, +) -> impl Stream<Item = Result<T, E>> { let (sender, receiver) = mpsc::channel(size); let runner = stream::once(f(sender)).filter_map(|result| async { |