diff options
author | 2021-01-04 22:58:39 +0300 | |
---|---|---|
committer | 2021-01-04 23:20:21 +0100 | |
commit | 50452e62b4df458d676fc95361b04ef2dd83aebf (patch) | |
tree | a8988fe89505da6675e846938080d8563157927d /futures | |
parent | 2665860b4ddff773bca9959fe828776ecb03ab7d (diff) | |
download | iced-50452e62b4df458d676fc95361b04ef2dd83aebf.tar.gz iced-50452e62b4df458d676fc95361b04ef2dd83aebf.tar.bz2 iced-50452e62b4df458d676fc95361b04ef2dd83aebf.zip |
Update `tokio` to `1.0`
Diffstat (limited to 'futures')
-rw-r--r-- | futures/Cargo.toml | 5 | ||||
-rw-r--r-- | futures/src/time.rs | 18 |
2 files changed, 18 insertions, 5 deletions
diff --git a/futures/Cargo.toml b/futures/Cargo.toml index e8e47c08..92b504a6 100644 --- a/futures/Cargo.toml +++ b/futures/Cargo.toml @@ -26,9 +26,10 @@ optional = true features = ["rt-core", "rt-threaded", "time", "stream"] [target.'cfg(not(target_arch = "wasm32"))'.dependencies.tokio] -version = "0.3" +package = "tokio" +version = "1.0" optional = true -features = ["rt-multi-thread", "time", "stream"] +features = ["rt", "rt-multi-thread", "time"] [target.'cfg(not(target_arch = "wasm32"))'.dependencies.async-std] version = "1.0" diff --git a/futures/src/time.rs b/futures/src/time.rs index 5e9ea436..7458af06 100644 --- a/futures/src/time.rs +++ b/futures/src/time.rs @@ -67,8 +67,20 @@ where let start = tokio::time::Instant::now() + self.0; - tokio::time::interval_at(start, self.0) - .map(|_| std::time::Instant::now()) - .boxed() + let stream = { + #[cfg(feature = "tokio")] + { + futures::stream::unfold( + tokio::time::interval_at(start, self.0), + |mut interval| async move { + Some((interval.tick().await, interval)) + }, + ) + } + #[cfg(feature = "tokio_old")] + tokio::time::interval_at(start, self.0) + }; + + stream.map(|_| std::time::Instant::now()).boxed() } } |