Remove UpdateListener::timeout_hint

This commit is contained in:
Maybe Waffle 2023-09-25 20:17:28 +04:00
parent 07e08bef6c
commit d3c69eb0c9
3 changed files with 7 additions and 41 deletions

View file

@ -32,8 +32,6 @@ pub mod webhooks;
use futures::Stream; use futures::Stream;
use std::time::Duration;
use crate::{ use crate::{
stop::StopToken, stop::StopToken,
types::{AllowedUpdate, Update}, types::{AllowedUpdate, Update},
@ -94,19 +92,6 @@ pub trait UpdateListener:
fn hint_allowed_updates(&mut self, hint: &mut dyn Iterator<Item = AllowedUpdate>) { fn hint_allowed_updates(&mut self, hint: &mut dyn Iterator<Item = AllowedUpdate>) {
let _ = hint; let _ = hint;
} }
/// The timeout duration hint.
///
/// This hints how often dispatcher should check for a shutdown. E.g., for
/// [`polling()`] this returns the [`timeout`].
///
/// [`timeout`]: crate::payloads::GetUpdates::timeout
///
/// If you are implementing this trait and not sure what to return from this
/// function, just leave it with the default implementation.
fn timeout_hint(&self) -> Option<Duration> {
None
}
} }
/// [`UpdateListener`]'s supertrait/extension. /// [`UpdateListener`]'s supertrait/extension.

View file

@ -301,10 +301,6 @@ impl<B: Requester + Send + 'static> UpdateListener for Polling<B> {
// before // before
self.allowed_updates = Some(hint.collect()); self.allowed_updates = Some(hint.collect());
} }
fn timeout_hint(&self) -> Option<Duration> {
self.timeout
}
} }
impl<'a, B: Requester + Send + 'a> AsUpdateStream<'a> for Polling<B> { impl<'a, B: Requester + Send + 'a> AsUpdateStream<'a> for Polling<B> {

View file

@ -1,5 +1,3 @@
use std::time::Duration;
use futures::Stream; use futures::Stream;
use crate::{ use crate::{
@ -17,7 +15,7 @@ use crate::{
/// ///
/// [`polling`]: crate::update_listeners::polling() /// [`polling`]: crate::update_listeners::polling()
#[non_exhaustive] #[non_exhaustive]
pub struct StatefulListener<St, Assf, Sf, Hauf, Thf> { pub struct StatefulListener<St, Assf, Sf, Hauf> {
/// The state of the listener. /// The state of the listener.
pub state: St, pub state: St,
@ -36,38 +34,30 @@ pub struct StatefulListener<St, Assf, Sf, Hauf, Thf> {
/// Must implement `FnMut(&mut St, &mut dyn Iterator<Item = /// Must implement `FnMut(&mut St, &mut dyn Iterator<Item =
/// AllowedUpdate>)`. /// AllowedUpdate>)`.
pub hint_allowed_updates: Option<Hauf>, pub hint_allowed_updates: Option<Hauf>,
/// The function used as [`UpdateListener::timeout_hint`].
///
/// Must implement `Fn(&St) -> Option<Duration>`.
pub timeout_hint: Option<Thf>,
} }
type Haufn<State> = for<'a, 'b> fn(&'a mut State, &'b mut dyn Iterator<Item = AllowedUpdate>); type Haufn<State> = for<'a, 'b> fn(&'a mut State, &'b mut dyn Iterator<Item = AllowedUpdate>);
type Thfn<State> = for<'a> fn(&'a State) -> Option<Duration>;
impl<St, Assf, Sf> StatefulListener<St, Assf, Sf, Haufn<St>, Thfn<St>> { impl<St, Assf, Sf> StatefulListener<St, Assf, Sf, Haufn<St>> {
/// Creates a new stateful listener from its components. /// Creates a new stateful listener from its components.
pub fn new(state: St, stream: Assf, stop_token: Sf) -> Self { pub fn new(state: St, stream: Assf, stop_token: Sf) -> Self {
Self::new_with_hints(state, stream, stop_token, None, None) Self::new_with_hints(state, stream, stop_token, None)
} }
} }
impl<St, Assf, Sf, Hauf, Thf> StatefulListener<St, Assf, Sf, Hauf, Thf> { impl<St, Assf, Sf, Hauf> StatefulListener<St, Assf, Sf, Hauf> {
/// Creates a new stateful listener from its components. /// Creates a new stateful listener from its components.
pub fn new_with_hints( pub fn new_with_hints(
state: St, state: St,
stream: Assf, stream: Assf,
stop_token: Sf, stop_token: Sf,
hint_allowed_updates: Option<Hauf>, hint_allowed_updates: Option<Hauf>,
timeout_hint: Option<Thf>,
) -> Self { ) -> Self {
Self { state, stream, stop_token, hint_allowed_updates, timeout_hint } Self { state, stream, stop_token, hint_allowed_updates }
} }
} }
impl<'a, St, Assf, Sf, Hauf, Thf, Strm, E> AsUpdateStream<'a> impl<'a, St, Assf, Sf, Hauf, Strm, E> AsUpdateStream<'a> for StatefulListener<St, Assf, Hauf, Sf>
for StatefulListener<St, Assf, Hauf, Sf, Thf>
where where
(St, Strm): 'a, (St, Strm): 'a,
Strm: Send, Strm: Send,
@ -82,12 +72,11 @@ where
} }
} }
impl<St, Assf, Sf, Hauf, Thf, E> UpdateListener for StatefulListener<St, Assf, Sf, Hauf, Thf> impl<St, Assf, Sf, Hauf, E> UpdateListener for StatefulListener<St, Assf, Sf, Hauf>
where where
Self: for<'a> AsUpdateStream<'a, StreamErr = E>, Self: for<'a> AsUpdateStream<'a, StreamErr = E>,
Sf: FnMut(&mut St) -> StopToken, Sf: FnMut(&mut St) -> StopToken,
Hauf: FnMut(&mut St, &mut dyn Iterator<Item = AllowedUpdate>), Hauf: FnMut(&mut St, &mut dyn Iterator<Item = AllowedUpdate>),
Thf: Fn(&St) -> Option<Duration>,
{ {
type Err = E; type Err = E;
@ -100,8 +89,4 @@ where
f(&mut self.state, hint); f(&mut self.state, hint);
} }
} }
fn timeout_hint(&self) -> Option<Duration> {
self.timeout_hint.as_ref().and_then(|f| f(&self.state))
}
} }