summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón Jiménez <hector@hecrj.dev>2025-02-11 02:34:10 +0100
committerLibravatar Héctor Ramón Jiménez <hector@hecrj.dev>2025-02-11 02:34:10 +0100
commit9f21eae1528fa414adbfb987ce4c851fa58326fe (patch)
tree4eff76cd5effe1b3fa51e4fe17c9a53aa9823841
parent06ece6a8c30541b7b2b6bcbb370fdffc9f1fcb79 (diff)
downloadiced-9f21eae1528fa414adbfb987ce4c851fa58326fe.tar.gz
iced-9f21eae1528fa414adbfb987ce4c851fa58326fe.tar.bz2
iced-9f21eae1528fa414adbfb987ce4c851fa58326fe.zip
Introduce `Task::map_with`
-rw-r--r--examples/download_progress/src/main.rs2
-rw-r--r--examples/gallery/src/main.rs18
-rw-r--r--futures/src/lib.rs1
-rw-r--r--runtime/src/task.rs44
-rw-r--r--src/lib.rs1
5 files changed, 55 insertions, 11 deletions
diff --git a/examples/download_progress/src/main.rs b/examples/download_progress/src/main.rs
index 8f59f1dc..cc7a7800 100644
--- a/examples/download_progress/src/main.rs
+++ b/examples/download_progress/src/main.rs
@@ -52,7 +52,7 @@ impl Example {
let task = download.start();
- task.map(move |update| Message::DownloadUpdated(index, update))
+ task.map_with(index, Message::DownloadUpdated)
}
Message::DownloadUpdated(id, update) => {
if let Some(download) =
diff --git a/examples/gallery/src/main.rs b/examples/gallery/src/main.rs
index ab22679d..441ad924 100644
--- a/examples/gallery/src/main.rs
+++ b/examples/gallery/src/main.rs
@@ -94,17 +94,15 @@ impl Gallery {
return Task::none();
};
- Task::batch(vec![
- Task::perform(
+ Task::batch([
+ Task::future(
image.clone().blurhash(Preview::WIDTH, Preview::HEIGHT),
- move |result| Message::BlurhashDecoded(id, result),
- ),
- Task::perform(
- image.download(Size::Thumbnail {
- width: Preview::WIDTH,
- }),
- move |result| Message::ThumbnailDownloaded(id, result),
- ),
+ )
+ .map_with(id, Message::BlurhashDecoded),
+ Task::future(image.download(Size::Thumbnail {
+ width: Preview::WIDTH,
+ }))
+ .map_with(id, Message::ThumbnailDownloaded),
])
}
Message::ImageDownloaded(Ok(rgba)) => {
diff --git a/futures/src/lib.rs b/futures/src/lib.rs
index a874a618..31738823 100644
--- a/futures/src/lib.rs
+++ b/futures/src/lib.rs
@@ -15,6 +15,7 @@ pub mod backend;
pub mod event;
pub mod executor;
pub mod keyboard;
+pub mod stream;
pub mod subscription;
pub use executor::Executor;
diff --git a/runtime/src/task.rs b/runtime/src/task.rs
index bfc36d75..1a1ef699 100644
--- a/runtime/src/task.rs
+++ b/runtime/src/task.rs
@@ -98,6 +98,50 @@ impl<T> Task<T> {
self.then(move |output| Task::done(f(output)))
}
+ /// Combines a prefix value with the result of the [`Task`] using
+ /// the provided closure.
+ ///
+ /// Sometimes you will want to identify the source or target
+ /// of some [`Task`] in your UI. This can be achieved through
+ /// normal means by using [`map`]:
+ ///
+ /// ```rust
+ /// # use iced_runtime::Task;
+ /// # let task = Task::none();
+ /// # enum Message { TaskCompleted(u32, ()) }
+ /// let id = 123;
+ ///
+ /// # let _ = {
+ /// task.map(move |result| Message::TaskCompleted(id, result))
+ /// # };
+ /// ```
+ ///
+ /// Quite a mouthful. [`map_with`] lets you write:
+ ///
+ /// ```rust
+ /// # use iced_runtime::Task;
+ /// # let task = Task::none();
+ /// # enum Message { TaskCompleted(u32, ()) }
+ /// # let id = 123;
+ /// # let _ = {
+ /// task.map_with(id, Message::TaskCompleted)
+ /// # };
+ /// ```
+ ///
+ /// Much nicer!
+ pub fn map_with<P, O>(
+ self,
+ prefix: P,
+ mut f: impl FnMut(P, T) -> O + MaybeSend + 'static,
+ ) -> Task<O>
+ where
+ T: MaybeSend + 'static,
+ P: MaybeSend + Clone + 'static,
+ O: MaybeSend + 'static,
+ {
+ self.map(move |result| f(prefix.clone(), result))
+ }
+
/// Performs a new [`Task`] for every output of the current [`Task`] using the
/// given closure.
///
diff --git a/src/lib.rs b/src/lib.rs
index 79992a3e..e4649938 100644
--- a/src/lib.rs
+++ b/src/lib.rs
@@ -478,6 +478,7 @@ use iced_winit::core;
use iced_winit::runtime;
pub use iced_futures::futures;
+pub use iced_futures::stream;
#[cfg(feature = "highlighter")]
pub use iced_highlighter as highlighter;