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
.
AbortRegistration
s 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?