Struct tokio::task::JoinError [−][src]
pub struct JoinError { /* fields omitted */ }
Task failed to execute to completion.
Implementations
impl JoinError
[src]
impl JoinError
[src]pub fn is_cancelled(&self) -> bool
[src]
Returns true if the error was caused by the task being cancelled
pub fn is_panic(&self) -> bool
[src]
Returns true if the error was caused by the task panicking
Examples
use std::panic; #[tokio::main] async fn main() { let err = tokio::spawn(async { panic!("boom"); }).await.unwrap_err(); assert!(err.is_panic()); }
pub fn into_panic(self) -> Box<dyn Any + Send + 'static>ⓘ
[src]
Consumes the join error, returning the object with which the task panicked.
Panics
into_panic()
panics if the Error
does not represent the underlying
task terminating with a panic. Use is_panic
to check the error reason
or try_into_panic
for a variant that does not panic.
Examples
ⓘ
use std::panic; #[tokio::main] async fn main() { let err = tokio::spawn(async { panic!("boom"); }).await.unwrap_err(); if err.is_panic() { // Resume the panic on the main task panic::resume_unwind(err.into_panic()); } }
pub fn try_into_panic(self) -> Result<Box<dyn Any + Send + 'static>, JoinError>
[src]
Consumes the join error, returning the object with which the task
panicked if the task terminated due to a panic. Otherwise, self
is
returned.
Examples
ⓘ
use std::panic; #[tokio::main] async fn main() { let err = tokio::spawn(async { panic!("boom"); }).await.unwrap_err(); if let Ok(reason) = err.try_into_panic() { // Resume the panic on the main task panic::resume_unwind(reason); } }