Struct mz_ore::task::JoinHandle
source · pub struct JoinHandle<T>(JoinHandle<T>);
Available on crate feature
async
only.Expand description
Wraps a tokio JoinHandle
and provides 4 exclusive (i.e. they take self
ownership)
operations:
abort_on_drop
: create anAbortOnDropHandle
that will automatically abort the task when the handle is dropped.JoinHandleExt::wait_and_assert_finished
: wait for the task to finish and return its return value.JoinHandleExt::abort_and_wait
: abort the task and wait for it to be finished.into_tokio_handle
: turn it into an ordinary tokioJoinHandle
.
Tuple Fields§
§0: JoinHandle<T>
Implementations§
source§impl<T> JoinHandle<T>
impl<T> JoinHandle<T>
sourcepub fn abort_on_drop(self) -> AbortOnDropHandle<T> ⓘ
pub fn abort_on_drop(self) -> AbortOnDropHandle<T> ⓘ
Create an AbortOnDropHandle
from this JoinHandle
.
sourcepub fn is_finished(&self) -> bool
pub fn is_finished(&self) -> bool
Checks if the task associated with this JoinHandle
has finished.a
sourcepub fn into_tokio_handle(self) -> TokioJoinHandle<T>
pub fn into_tokio_handle(self) -> TokioJoinHandle<T>
Checks if the task associated with this JoinHandle
has finished.a
Trait Implementations§
source§impl<T: Debug> Debug for JoinHandle<T>
impl<T: Debug> Debug for JoinHandle<T>
source§impl<T> Future for JoinHandle<T>
impl<T> Future for JoinHandle<T>
source§impl<T: Send> JoinHandleExt<T> for JoinHandle<T>
impl<T: Send> JoinHandleExt<T> for JoinHandle<T>
Auto Trait Implementations§
impl<T> Freeze for JoinHandle<T>
impl<T> RefUnwindSafe for JoinHandle<T>
impl<T> Send for JoinHandle<T>where
T: Send,
impl<T> Sync for JoinHandle<T>where
T: Send,
impl<T> Unpin for JoinHandle<T>
impl<T> UnwindSafe for JoinHandle<T>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> FutureExt for T
impl<T> FutureExt for T
source§fn map<U, F>(self, f: F) -> Map<Self, F>
fn map<U, F>(self, f: F) -> Map<Self, F>
Map this future’s output to a different type, returning a new future of
the resulting type. Read more
source§fn map_into<U>(self) -> MapInto<Self, U>
fn map_into<U>(self) -> MapInto<Self, U>
Map this future’s output to a different type, returning a new future of
the resulting type. Read more
source§fn then<Fut, F>(self, f: F) -> Then<Self, Fut, F>
fn then<Fut, F>(self, f: F) -> Then<Self, Fut, F>
Chain on a computation for when a future finished, passing the result of
the future to the provided closure
f
. Read moresource§fn left_future<B>(self) -> Either<Self, B>
fn left_future<B>(self) -> Either<Self, B>
source§fn right_future<A>(self) -> Either<A, Self>
fn right_future<A>(self) -> Either<A, Self>
source§fn into_stream(self) -> IntoStream<Self>where
Self: Sized,
fn into_stream(self) -> IntoStream<Self>where
Self: Sized,
Convert this future into a single element stream. Read more
source§fn flatten(self) -> Flatten<Self>
fn flatten(self) -> Flatten<Self>
Flatten the execution of this future when the output of this
future is itself another future. Read more
source§fn flatten_stream(self) -> FlattenStream<Self>
fn flatten_stream(self) -> FlattenStream<Self>
Flatten the execution of this future when the successful result of this
future is a stream. Read more
source§fn fuse(self) -> Fuse<Self>where
Self: Sized,
fn fuse(self) -> Fuse<Self>where
Self: Sized,
Fuse a future such that
poll
will never again be called once it has
completed. This method can be used to turn any Future
into a
FusedFuture
. Read moresource§fn inspect<F>(self, f: F) -> Inspect<Self, F>
fn inspect<F>(self, f: F) -> Inspect<Self, F>
Do something with the output of a future before passing it on. Read more
source§fn catch_unwind(self) -> CatchUnwind<Self>where
Self: Sized + UnwindSafe,
fn catch_unwind(self) -> CatchUnwind<Self>where
Self: Sized + UnwindSafe,
Catches unwinding panics while polling the future. Read more
Create a cloneable handle to this future where all handles will resolve
to the same result. Read more
source§fn remote_handle(self) -> (Remote<Self>, RemoteHandle<Self::Output>)where
Self: Sized,
fn remote_handle(self) -> (Remote<Self>, RemoteHandle<Self::Output>)where
Self: Sized,
Turn this future into a future that yields
()
on completion and sends
its output to another future on a separate task. Read moresource§fn boxed<'a>(self) -> Pin<Box<dyn Future<Output = Self::Output> + Send + 'a>>
fn boxed<'a>(self) -> Pin<Box<dyn Future<Output = Self::Output> + Send + 'a>>
Wrap the future in a Box, pinning it. Read more
source§fn boxed_local<'a>(self) -> Pin<Box<dyn Future<Output = Self::Output> + 'a>>where
Self: Sized + 'a,
fn boxed_local<'a>(self) -> Pin<Box<dyn Future<Output = Self::Output> + 'a>>where
Self: Sized + 'a,
Wrap the future in a Box, pinning it. Read more
source§fn unit_error(self) -> UnitError<Self>where
Self: Sized,
fn unit_error(self) -> UnitError<Self>where
Self: Sized,
Turns a
Future<Output = T>
into a
TryFuture<Ok = T, Error = ()
>.source§fn never_error(self) -> NeverError<Self>where
Self: Sized,
fn never_error(self) -> NeverError<Self>where
Self: Sized,
Turns a
Future<Output = T>
into a
TryFuture<Ok = T, Error = Never
>.source§impl<T> FutureExt for T
impl<T> FutureExt for T
source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<F> IntoFuture for Fwhere
F: Future,
impl<F> IntoFuture for Fwhere
F: Future,
§type IntoFuture = F
type IntoFuture = F
Which kind of future are we turning this into?
source§fn into_future(self) -> <F as IntoFuture>::IntoFuture
fn into_future(self) -> <F as IntoFuture>::IntoFuture
Creates a future from a value. Read more
source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T
in a tonic::Request
source§impl<F> MetricsFutureExt<F> for Fwhere
F: Future,
impl<F> MetricsFutureExt<F> for Fwhere
F: Future,
source§fn wall_time(self) -> WallTimeFuture<F, UnspecifiedMetric> ⓘ
fn wall_time(self) -> WallTimeFuture<F, UnspecifiedMetric> ⓘ
Available on crate feature
metrics
only.source§fn exec_time(self) -> ExecTimeFuture<F, UnspecifiedMetric> ⓘ
fn exec_time(self) -> ExecTimeFuture<F, UnspecifiedMetric> ⓘ
Available on crate feature
metrics
only.source§impl<T> OreFutureExt for Twhere
T: Future,
impl<T> OreFutureExt for Twhere
T: Future,
source§fn spawn_if_canceled<Name, NameClosure>(
self,
nc: NameClosure,
) -> SpawnIfCanceled<<T as Future>::Output, Name, NameClosure> ⓘ
fn spawn_if_canceled<Name, NameClosure>( self, nc: NameClosure, ) -> SpawnIfCanceled<<T as Future>::Output, Name, NameClosure> ⓘ
Available on crate feature
async
only.Wraps a future in a
SpawnIfCanceled
future, which will spawn a
task to poll the inner future to completion if it is dropped.source§fn run_in_task<'async_trait, Name, NameClosure>(
self,
nc: NameClosure,
) -> Pin<Box<dyn Future<Output = <T as Future>::Output> + Send + 'async_trait>>
fn run_in_task<'async_trait, Name, NameClosure>( self, nc: NameClosure, ) -> Pin<Box<dyn Future<Output = <T as Future>::Output> + Send + 'async_trait>>
Available on crate feature
async
only.Run a
'static
future in a Tokio task, naming that task, using a convenient
postfix call notation. Read moresource§fn run_in_task_if<'async_trait, Name, NameClosure>(
self,
in_task: InTask,
nc: NameClosure,
) -> Pin<Box<dyn Future<Output = <T as Future>::Output> + Send + 'async_trait>>
fn run_in_task_if<'async_trait, Name, NameClosure>( self, in_task: InTask, nc: NameClosure, ) -> Pin<Box<dyn Future<Output = <T as Future>::Output> + Send + 'async_trait>>
Available on crate feature
async
only.The same as
run_in_task
, but allows the callee to dynamically choose whether or
not the future is polled into a Tokio task.source§fn ore_catch_unwind(self) -> OreCatchUnwind<T> ⓘwhere
T: UnwindSafe,
fn ore_catch_unwind(self) -> OreCatchUnwind<T> ⓘwhere
T: UnwindSafe,
Available on crate feature
async
only.Like
FutureExt::catch_unwind
, but can unwind panics even if
panic::install_enhanced_handler
has been called.source§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<F> SentryFutureExt for Fwhere
F: Future,
impl<F> SentryFutureExt for Fwhere
F: Future,
source§impl<Fut> TryFutureExt for Fut
impl<Fut> TryFutureExt for Fut
source§fn flatten_sink<Item>(self) -> FlattenSink<Self, Self::Ok>
fn flatten_sink<Item>(self) -> FlattenSink<Self, Self::Ok>
source§fn map_ok<T, F>(self, f: F) -> MapOk<Self, F>
fn map_ok<T, F>(self, f: F) -> MapOk<Self, F>
Maps this future’s success value to a different value. Read more
source§fn map_ok_or_else<T, E, F>(self, e: E, f: F) -> MapOkOrElse<Self, F, E>
fn map_ok_or_else<T, E, F>(self, e: E, f: F) -> MapOkOrElse<Self, F, E>
Maps this future’s success value to a different value, and permits for error handling resulting in the same type. Read more
source§fn map_err<E, F>(self, f: F) -> MapErr<Self, F>
fn map_err<E, F>(self, f: F) -> MapErr<Self, F>
Maps this future’s error value to a different value. Read more
source§fn and_then<Fut, F>(self, f: F) -> AndThen<Self, Fut, F>
fn and_then<Fut, F>(self, f: F) -> AndThen<Self, Fut, F>
Executes another future after this one resolves successfully. The
success value is passed to a closure to create this subsequent future. Read more
source§fn or_else<Fut, F>(self, f: F) -> OrElse<Self, Fut, F>
fn or_else<Fut, F>(self, f: F) -> OrElse<Self, Fut, F>
Executes another future if this one resolves to an error. The
error value is passed to a closure to create this subsequent future. Read more
source§fn inspect_ok<F>(self, f: F) -> InspectOk<Self, F>
fn inspect_ok<F>(self, f: F) -> InspectOk<Self, F>
Do something with the success value of a future before passing it on. Read more
source§fn inspect_err<F>(self, f: F) -> InspectErr<Self, F>
fn inspect_err<F>(self, f: F) -> InspectErr<Self, F>
Do something with the error value of a future before passing it on. Read more
source§fn try_flatten(self) -> TryFlatten<Self, Self::Ok>
fn try_flatten(self) -> TryFlatten<Self, Self::Ok>
Flatten the execution of this future when the successful result of this
future is another future. Read more
source§fn try_flatten_stream(self) -> TryFlattenStream<Self>
fn try_flatten_stream(self) -> TryFlattenStream<Self>
Flatten the execution of this future when the successful result of this
future is a stream. Read more