pub struct Task<T> { /* private fields */ }Expand description
A handle to a spawned task.
This is a wrapper around tokio’s JoinHandle that provides a consistent API.
When awaited, returns Result<T, TaskError>:
Ok(T): The task completed successfullyErr(TaskError): The task panicked or was aborted/cancelled
§Example
use sansio_executor::{LocalExecutorBuilder, spawn_local};
LocalExecutorBuilder::default().run(async {
let task = spawn_local(async { 42 });
let result = task.await.unwrap();
assert_eq!(result, 42);
});Implementations§
Source§impl<T> Task<T>
impl<T> Task<T>
Sourcepub fn detach(self)
pub fn detach(self)
Detaches the task, allowing it to run in the background.
This consumes the task handle and allows the task to continue running without being awaited. The task will run to completion in the background.
§Example
use sansio_executor::{LocalExecutorBuilder, spawn_local};
LocalExecutorBuilder::default().run(async {
let task = spawn_local(async {
println!("Running in background");
});
// Detach the task - it continues running
task.detach();
// We can't await it anymore, but it will complete
});Sourcepub fn cancel(self)
pub fn cancel(self)
Cancels the task.
This immediately aborts the task’s execution.
§Example
use sansio_executor::{LocalExecutorBuilder, spawn_local};
LocalExecutorBuilder::default().run(async {
let task = spawn_local(async {
println!("This will not print");
});
// Cancel the task
task.cancel();
});Trait Implementations§
Auto Trait Implementations§
impl<T> Freeze for Task<T>
impl<T> RefUnwindSafe for Task<T>
impl<T> Send for Task<T>where
T: Send,
impl<T> Sync for Task<T>where
T: Send,
impl<T> Unpin for Task<T>
impl<T> UnwindSafe for Task<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<F> IntoFuture for Fwhere
F: Future,
impl<F> IntoFuture for Fwhere
F: Future,
Source§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