From f37d068af52700570f863960c3432df85a244a7c Mon Sep 17 00:00:00 2001 From: Héctor Ramón Jiménez Date: Tue, 11 Feb 2025 01:27:51 +0100 Subject: Rewrite `websocket` example using `sipper` --- futures/src/backend/native/tokio.rs | 11 +++++------ futures/src/lib.rs | 1 - 2 files changed, 5 insertions(+), 7 deletions(-) (limited to 'futures') diff --git a/futures/src/backend/native/tokio.rs b/futures/src/backend/native/tokio.rs index e0be83a6..c38ef566 100644 --- a/futures/src/backend/native/tokio.rs +++ b/futures/src/backend/native/tokio.rs @@ -23,11 +23,10 @@ impl crate::Executor for Executor { pub mod time { //! Listen and react to time. use crate::core::time::{Duration, Instant}; - use crate::stream; use crate::subscription::Subscription; use crate::MaybeSend; - use futures::SinkExt; + use futures::stream; use std::future::Future; /// Returns a [`Subscription`] that produces messages at a set interval. @@ -66,12 +65,12 @@ pub mod time { let f = *f; let interval = *interval; - stream::channel(1, move |mut output| async move { - loop { - let _ = output.send(f().await).await; - + stream::unfold(0, move |i| async move { + if i > 0 { tokio::time::sleep(interval).await; } + + Some((f().await, i + 1)) }) }) } diff --git a/futures/src/lib.rs b/futures/src/lib.rs index 31738823..a874a618 100644 --- a/futures/src/lib.rs +++ b/futures/src/lib.rs @@ -15,7 +15,6 @@ pub mod backend; pub mod event; pub mod executor; pub mod keyboard; -pub mod stream; pub mod subscription; pub use executor::Executor; -- cgit