diff options
| author | 2023-02-23 08:15:26 -0800 | |
|---|---|---|
| committer | 2023-02-23 08:15:26 -0800 | |
| commit | a131f11a23d3430df58bf67a7c89f4b2284822af (patch) | |
| tree | 038b36a8ed6007b8e6288b212e9ff81d350c4db5 /native | |
| parent | 50b9c778b1e49fc83f827a340dce36a09bb291d6 (diff) | |
| parent | 666f3cd143047e49a010f0c97eabc7136f92aa35 (diff) | |
| download | iced-a131f11a23d3430df58bf67a7c89f4b2284822af.tar.gz iced-a131f11a23d3430df58bf67a7c89f4b2284822af.tar.bz2 iced-a131f11a23d3430df58bf67a7c89f4b2284822af.zip | |
Merge remote-tracking branch 'origin/master' into feat/multi-window-support
Diffstat (limited to 'native')
| -rw-r--r-- | native/src/subscription.rs | 17 | 
1 files changed, 15 insertions, 2 deletions
| diff --git a/native/src/subscription.rs b/native/src/subscription.rs index 859abe8e..2a216ebe 100644 --- a/native/src/subscription.rs +++ b/native/src/subscription.rs @@ -100,11 +100,24 @@ where      })  } +/// Returns a [`Subscription`] that will call the given function to create and +/// asynchronously run the given [`Stream`]. +pub fn run<S, Message>(builder: fn() -> S) -> Subscription<Message> +where +    S: Stream<Item = Message> + MaybeSend + 'static, +    Message: 'static, +{ +    Subscription::from_recipe(Runner { +        id: builder, +        spawn: move |_| builder(), +    }) +} +  /// Returns a [`Subscription`] that will create and asynchronously run the  /// given [`Stream`].  ///  /// The `id` will be used to uniquely identify the [`Subscription`]. -pub fn run<I, S, Message>(id: I, stream: S) -> Subscription<Message> +pub fn run_with_id<I, S, Message>(id: I, stream: S) -> Subscription<Message>  where      I: Hash + 'static,      S: Stream<Item = Message> + MaybeSend + 'static, @@ -199,7 +212,7 @@ where      use futures::future::{self, FutureExt};      use futures::stream::StreamExt; -    run( +    run_with_id(          id,          futures::stream::unfold(initial, move |state| f(state).map(Some))              .filter_map(future::ready), | 
