Struct futures_util::future::Abortable [−][src]
#[must_use = "futures do nothing unless you `.await` or poll them"]pub struct Abortable<Fut> { /* fields omitted */ }
A future which can be remotely short-circuited using an AbortHandle.
Implementations
impl<Fut> Abortable<Fut> where
Fut: Future, [src]
impl<Fut> Abortable<Fut> where
Fut: Future, [src]pub fn new(future: Fut, reg: AbortRegistration) -> Self[src]
Creates a new Abortable future using an existing AbortRegistration.
AbortRegistrations can be acquired through AbortHandle::new.
When abort is called on the handle tied to reg or if abort has
already been called, the future will complete immediately without making
any further progress.
Example:
use futures::future::{Abortable, AbortHandle, Aborted}; let (abort_handle, abort_registration) = AbortHandle::new_pair(); let future = Abortable::new(async { 2 }, abort_registration); abort_handle.abort(); assert_eq!(future.await, Err(Aborted));
Trait Implementations
impl<'__pin, Fut> Unpin for Abortable<Fut> where
__Origin<'__pin, Fut>: Unpin, [src]
__Origin<'__pin, Fut>: Unpin,
Auto Trait Implementations
impl<Fut> !RefUnwindSafe for Abortable<Fut>
impl<Fut> Send for Abortable<Fut> where
Fut: Send,
Fut: Send,
impl<Fut> Sync for Abortable<Fut> where
Fut: Sync,
Fut: Sync,
impl<Fut> !UnwindSafe for Abortable<Fut>
Blanket Implementations
impl<F> IntoFuture for F where
F: Future, [src]
impl<F> IntoFuture for F where
F: Future, [src]type Output = <F as Future>::Output
🔬 This is a nightly-only experimental API. (
into_future)The output that the future will produce on completion.
type Future = F
🔬 This is a nightly-only experimental API. (
into_future)Which kind of future are we turning this into?