mirror of
https://github.com/teloxide/teloxide.git
synced 2025-01-05 10:24:32 +01:00
parent
5c40bfa78c
commit
1fad4ab3b3
1 changed files with 5 additions and 8 deletions
13
src/stop.rs
13
src/stop.rs
|
@ -5,7 +5,7 @@
|
||||||
//! [flag]: StopFlag
|
//! [flag]: StopFlag
|
||||||
//! [listeners]: crate::dispatching::update_listeners
|
//! [listeners]: crate::dispatching::update_listeners
|
||||||
|
|
||||||
use std::{future::Future, pin::Pin, task};
|
use std::{convert::Infallible, future::Future, pin::Pin, task};
|
||||||
|
|
||||||
use futures::future::{pending, AbortHandle, Abortable, Pending};
|
use futures::future::{pending, AbortHandle, Abortable, Pending};
|
||||||
|
|
||||||
|
@ -31,7 +31,7 @@ pub struct StopToken(AbortHandle);
|
||||||
/// [`is_stopped`]: StopFlag::is_stopped
|
/// [`is_stopped`]: StopFlag::is_stopped
|
||||||
#[pin_project::pin_project]
|
#[pin_project::pin_project]
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub struct StopFlag(#[pin] Abortable<Pending<()>>);
|
pub struct StopFlag(#[pin] Abortable<Pending<Infallible>>);
|
||||||
|
|
||||||
impl StopToken {
|
impl StopToken {
|
||||||
/// "Stops" the flag associated with this token.
|
/// "Stops" the flag associated with this token.
|
||||||
|
@ -56,12 +56,9 @@ impl Future for StopFlag {
|
||||||
type Output = ();
|
type Output = ();
|
||||||
|
|
||||||
fn poll(self: Pin<&mut Self>, cx: &mut task::Context<'_>) -> task::Poll<Self::Output> {
|
fn poll(self: Pin<&mut Self>, cx: &mut task::Context<'_>) -> task::Poll<Self::Output> {
|
||||||
self.project().0.poll(cx).map(|res| {
|
self.project().0.poll(cx).map(|res| match res {
|
||||||
debug_assert!(
|
Err(_aborted) => (),
|
||||||
res.is_err(),
|
Ok(unreachable) => match unreachable {},
|
||||||
"Pending Future can't ever be resolved, so Abortable is only resolved when \
|
|
||||||
canceled"
|
|
||||||
);
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue