Skip to main content

LocalExecutor

Struct LocalExecutor 

Source
pub struct LocalExecutor { /* private fields */ }
Expand description

A !Send executor pinned to a single session. Tasks spawned on it run in order on whichever thread drains the dispatch destination supplied at construction time — typically the main thread for the default session, or a dedicated OS thread for sessions created by spawn_dedicated_thread.

Implementations§

Source§

impl LocalExecutor

Source

pub fn new( session_id: SessionId, scheduler: Arc<dyn Scheduler>, dispatch: impl Fn(Runnable<RunnableMeta>) + Send + Sync + 'static, ) -> Self

Constructs a local executor that runs spawned tasks by sending their runnables through dispatch. The scheduler is retained for access to clocks, timers, and other scheduler-level services.

For the common case of routing runnables through Scheduler::schedule_local, callers pass a closure that does exactly that. spawn_dedicated_thread instead passes a closure that sends to the dedicated thread’s channel.

Source

pub fn session_id(&self) -> SessionId

Source

pub fn scheduler(&self) -> &Arc<dyn Scheduler>

Source

pub fn spawn<F>(&self, future: F) -> Task<F::Output>
where F: Future + 'static, F::Output: 'static,

Source

pub fn block_on<Fut: Future>(&self, future: Fut) -> Fut::Output

Source

pub fn block_with_timeout<Fut: Future>( &self, timeout: Duration, future: Fut, ) -> Result<Fut::Output, impl Future<Output = Fut::Output> + use<Fut>>

Block until the future completes or timeout occurs. Returns Ok(output) if completed, Err(future) if timed out.

Source

pub fn timer(&self, duration: Duration) -> Timer

Source

pub fn now(&self) -> Instant

Source

pub fn spawn_dedicated<F, Fut>(&self, f: F) -> Task<Fut::Output>
where F: FnOnce(LocalExecutor) -> Fut + Send + 'static, Fut: Future + 'static, Fut::Output: Send + Sync + 'static,

Spawn a closure on a fresh session pinned to its own LocalExecutor. The closure runs on a new OS thread under PlatformScheduler, or on the test scheduler’s loop under TestScheduler.

The returned Task represents the dedicated work: dropping it cancels the dedicated closure, .awaiting it yields the closure’s return value, .detach()ing it lets the dedicated work run independently of the caller.

Trait Implementations§

Source§

impl Clone for LocalExecutor

Source§

fn clone(&self) -> LocalExecutor

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more

Auto Trait Implementations§

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<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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<T> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V