diff options
author | 2024-07-11 04:08:40 +0200 | |
---|---|---|
committer | 2024-07-11 04:08:40 +0200 | |
commit | 4ce2a207a6c2f28345dc86804a12f2faab3d07ab (patch) | |
tree | 3eb240ece3e47133d457b02a26c8ddd24a9c543e /futures/src/stream.rs | |
parent | 70f44a6e264f7307531935bf0fb9e33a5ebd81c1 (diff) | |
download | iced-4ce2a207a6c2f28345dc86804a12f2faab3d07ab.tar.gz iced-4ce2a207a6c2f28345dc86804a12f2faab3d07ab.tar.bz2 iced-4ce2a207a6c2f28345dc86804a12f2faab3d07ab.zip |
Introduce `stream::try_channel` helper
Diffstat (limited to '')
-rw-r--r-- | futures/src/stream.rs | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/futures/src/stream.rs b/futures/src/stream.rs index 06f9230d..af2f8c99 100644 --- a/futures/src/stream.rs +++ b/futures/src/stream.rs @@ -23,3 +23,24 @@ where stream::select(receiver, runner) } + +/// 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>( + size: usize, + f: impl FnOnce(mpsc::Sender<T>) -> F, +) -> impl Stream<Item = Result<T, E>> +where + F: Future<Output = Result<(), E>>, +{ + let (sender, receiver) = mpsc::channel(size); + + let runner = stream::once(f(sender)).filter_map(|result| async { + match result { + Ok(()) => None, + Err(error) => Some(Err(error)), + } + }); + + stream::select(receiver.map(Ok), runner) +} |