Task

Struct Task 

Source
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 successfully
  • Err(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>

Source

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
});
Source

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§

Source§

impl<T> Future for Task<T>

Source§

type Output = Result<T, TaskError>

The type of value produced on completion.
Source§

fn poll(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output>

Attempts to resolve the future to a final value, registering the current task for wakeup if the value is not yet available. Read more

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> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<F> IntoFuture for F
where F: Future,

Source§

type Output = <F as Future>::Output

The output that the future will produce on completion.
Source§

type IntoFuture = F

Which kind of future are we turning this into?
Source§

fn into_future(self) -> <F as IntoFuture>::IntoFuture

Creates a future from a value. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.