diff options
Diffstat (limited to 'futures/src/backend/native')
| -rw-r--r-- | futures/src/backend/native/async_std.rs | 14 | ||||
| -rw-r--r-- | futures/src/backend/native/smol.rs | 16 | ||||
| -rw-r--r-- | futures/src/backend/native/thread_pool.rs | 1 | ||||
| -rw-r--r-- | futures/src/backend/native/tokio.rs | 14 | 
4 files changed, 18 insertions, 27 deletions
| diff --git a/futures/src/backend/native/async_std.rs b/futures/src/backend/native/async_std.rs index b324dbf1..52b0e914 100644 --- a/futures/src/backend/native/async_std.rs +++ b/futures/src/backend/native/async_std.rs @@ -18,28 +18,26 @@ impl crate::Executor for Executor {  pub mod time {      //! Listen and react to time. +    use crate::core::Hasher;      use crate::subscription::{self, Subscription};      /// Returns a [`Subscription`] that produces messages at a set interval.      ///      /// The first message is produced after a `duration`, and then continues to      /// produce more messages every `duration` after that. -    pub fn every<H: std::hash::Hasher, E>( +    pub fn every(          duration: std::time::Duration, -    ) -> Subscription<H, E, std::time::Instant> { +    ) -> Subscription<std::time::Instant> {          Subscription::from_recipe(Every(duration))      }      #[derive(Debug)]      struct Every(std::time::Duration); -    impl<H, E> subscription::Recipe<H, E> for Every -    where -        H: std::hash::Hasher, -    { +    impl subscription::Recipe for Every {          type Output = std::time::Instant; -        fn hash(&self, state: &mut H) { +        fn hash(&self, state: &mut Hasher) {              use std::hash::Hash;              std::any::TypeId::of::<Self>().hash(state); @@ -48,7 +46,7 @@ pub mod time {          fn stream(              self: Box<Self>, -            _input: futures::stream::BoxStream<'static, E>, +            _input: subscription::EventStream,          ) -> futures::stream::BoxStream<'static, Self::Output> {              use futures::stream::StreamExt; diff --git a/futures/src/backend/native/smol.rs b/futures/src/backend/native/smol.rs index d5201cde..00d13d35 100644 --- a/futures/src/backend/native/smol.rs +++ b/futures/src/backend/native/smol.rs @@ -1,9 +1,7 @@  //! A `smol` backend. -  use futures::Future;  /// A `smol` executor. -#[cfg_attr(docsrs, doc(cfg(feature = "smol")))]  #[derive(Debug)]  pub struct Executor; @@ -19,28 +17,26 @@ impl crate::Executor for Executor {  pub mod time {      //! Listen and react to time. +    use crate::core::Hasher;      use crate::subscription::{self, Subscription};      /// Returns a [`Subscription`] that produces messages at a set interval.      ///      /// The first message is produced after a `duration`, and then continues to      /// produce more messages every `duration` after that. -    pub fn every<H: std::hash::Hasher, E>( +    pub fn every(          duration: std::time::Duration, -    ) -> Subscription<H, E, std::time::Instant> { +    ) -> Subscription<std::time::Instant> {          Subscription::from_recipe(Every(duration))      }      #[derive(Debug)]      struct Every(std::time::Duration); -    impl<H, E> subscription::Recipe<H, E> for Every -    where -        H: std::hash::Hasher, -    { +    impl subscription::Recipe for Every {          type Output = std::time::Instant; -        fn hash(&self, state: &mut H) { +        fn hash(&self, state: &mut Hasher) {              use std::hash::Hash;              std::any::TypeId::of::<Self>().hash(state); @@ -49,7 +45,7 @@ pub mod time {          fn stream(              self: Box<Self>, -            _input: futures::stream::BoxStream<'static, E>, +            _input: subscription::EventStream,          ) -> futures::stream::BoxStream<'static, Self::Output> {              use futures::stream::StreamExt; diff --git a/futures/src/backend/native/thread_pool.rs b/futures/src/backend/native/thread_pool.rs index da5d4b9b..c96f2682 100644 --- a/futures/src/backend/native/thread_pool.rs +++ b/futures/src/backend/native/thread_pool.rs @@ -2,7 +2,6 @@  use futures::Future;  /// A thread pool executor for futures. -#[cfg_attr(docsrs, doc(cfg(feature = "thread-pool")))]  pub type Executor = futures::executor::ThreadPool;  impl crate::Executor for Executor { diff --git a/futures/src/backend/native/tokio.rs b/futures/src/backend/native/tokio.rs index dd818bd1..4698a105 100644 --- a/futures/src/backend/native/tokio.rs +++ b/futures/src/backend/native/tokio.rs @@ -22,28 +22,26 @@ impl crate::Executor for Executor {  pub mod time {      //! Listen and react to time. +    use crate::core::Hasher;      use crate::subscription::{self, Subscription};      /// Returns a [`Subscription`] that produces messages at a set interval.      ///      /// The first message is produced after a `duration`, and then continues to      /// produce more messages every `duration` after that. -    pub fn every<H: std::hash::Hasher, E>( +    pub fn every(          duration: std::time::Duration, -    ) -> Subscription<H, E, std::time::Instant> { +    ) -> Subscription<std::time::Instant> {          Subscription::from_recipe(Every(duration))      }      #[derive(Debug)]      struct Every(std::time::Duration); -    impl<H, E> subscription::Recipe<H, E> for Every -    where -        H: std::hash::Hasher, -    { +    impl subscription::Recipe for Every {          type Output = std::time::Instant; -        fn hash(&self, state: &mut H) { +        fn hash(&self, state: &mut Hasher) {              use std::hash::Hash;              std::any::TypeId::of::<Self>().hash(state); @@ -52,7 +50,7 @@ pub mod time {          fn stream(              self: Box<Self>, -            _input: futures::stream::BoxStream<'static, E>, +            _input: subscription::EventStream,          ) -> futures::stream::BoxStream<'static, Self::Output> {              use futures::stream::StreamExt; | 
