diff options
author | 2023-11-29 00:12:48 +0100 | |
---|---|---|
committer | 2023-11-29 00:12:48 +0100 | |
commit | 3b7d479534d9114ed12bb5d9ccd910e85d5c13c7 (patch) | |
tree | ab5c3e2a8f074d9a02dd470bfd659fb1740bf82a /futures | |
parent | 133f4da9014fcdc331ac44269209ee61ca56d007 (diff) | |
download | iced-3b7d479534d9114ed12bb5d9ccd910e85d5c13c7.tar.gz iced-3b7d479534d9114ed12bb5d9ccd910e85d5c13c7.tar.bz2 iced-3b7d479534d9114ed12bb5d9ccd910e85d5c13c7.zip |
Implement `Command::run` for executing a `Stream` to completion
Diffstat (limited to 'futures')
-rw-r--r-- | futures/src/runtime.rs | 25 |
1 files changed, 24 insertions, 1 deletions
diff --git a/futures/src/runtime.rs b/futures/src/runtime.rs index 16111b36..cac7b7e1 100644 --- a/futures/src/runtime.rs +++ b/futures/src/runtime.rs @@ -1,7 +1,7 @@ //! Run commands and keep track of subscriptions. use crate::core::event::{self, Event}; use crate::subscription; -use crate::{BoxFuture, Executor, MaybeSend}; +use crate::{BoxFuture, BoxStream, Executor, MaybeSend}; use futures::{channel::mpsc, Sink}; use std::marker::PhantomData; @@ -69,6 +69,29 @@ where self.executor.spawn(future); } + /// Runs a [`Stream`] in the [`Runtime`] until completion. + /// + /// The resulting `Message`s will be forwarded to the `Sender` of the + /// [`Runtime`]. + /// + /// [`Stream`]: BoxStream + pub fn run(&mut self, stream: BoxStream<Message>) { + use futures::{FutureExt, StreamExt}; + + let sender = self.sender.clone(); + let future = + stream.map(Ok).forward(sender).map(|result| match result { + Ok(()) => (), + Err(error) => { + log::warn!( + "Stream could not run until completion: {error}" + ); + } + }); + + self.executor.spawn(future); + } + /// Tracks a [`Subscription`] in the [`Runtime`]. /// /// It will spawn new streams or close old ones as necessary! See |