Skip to main content

DelayExecutor

Struct DelayExecutor 

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

Executor that starts each task after a fixed delay.

DelayExecutor is a small non-blocking submission strategy for cases where one task should run later while the caller must return immediately. It models delayed start, not minimum execution duration.

Each accepted task gets its own helper OS thread. The helper thread sleeps for the configured delay and then runs the task. This keeps the submitting thread unblocked without requiring a shared timer, queue, runtime, or scheduler worker. It is intentionally not a general-purpose delayed task scheduler and does not coalesce timers across tasks.

The returned TrackedTask is created immediately. Dropping the handle does not cancel the helper thread; use TrackedTask::cancel before the helper thread starts the task when pre-start cancellation is needed.

Implementations§

Source§

impl DelayExecutor

Source

pub fn new(delay: Duration) -> Self

Creates an executor that delays task start by the supplied duration.

§Parameters
  • delay - Duration to wait before running each task.
§Returns

A delay executor using the supplied delay.

Source

pub fn with_hook(self, hook: Arc<dyn TaskHook>) -> Self

Returns a copy of this executor using the supplied task hook.

§Parameters
  • hook - Hook notified about accepted task lifecycle events.
§Returns

This executor configured with hook.

Source

pub fn with_stack_size(self, stack_size: usize) -> Self

Returns a copy of this executor using the supplied helper thread stack size.

§Parameters
  • stack_size - Stack size in bytes for each helper thread.
§Returns

This executor configured with stack_size.

Source

pub const fn delay(&self) -> Duration

Returns the configured delay.

§Returns

The duration waited before each task starts.

Trait Implementations§

Source§

impl Clone for DelayExecutor

Source§

fn clone(&self) -> DelayExecutor

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
Source§

impl Executor for DelayExecutor

Source§

fn call<C, R, E>(&self, task: C) -> Result<TrackedTask<R, E>, SubmissionError>
where C: Callable<R, E> + Send + 'static, R: Send + 'static, E: Send + 'static,

Starts a helper thread that waits and then runs the callable.

This method returns after the helper thread has been spawned; it does not wait for the configured delay or for task completion.

§Parameters
  • task - Callable to run after the configured delay.
§Returns

A TrackedTask for the delayed task.

§Errors

Returns SubmissionError::WorkerSpawnFailed if the helper thread cannot be created.

Source§

fn execute<T, E>(&self, task: T) -> Result<TrackedTask<(), E>, SubmissionError>
where T: Runnable<E> + Send + 'static, E: Send + 'static,

Submits a runnable task and returns a tracked task handle. 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<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> DropFlavorWrapper<T> for T

Source§

type Flavor = MayDrop

The DropFlavor that wraps T into Self
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, W> HasTypeWitness<W> for T
where W: MakeTypeWitness<Arg = T>, T: ?Sized,

Source§

const WITNESS: W = W::MAKE

A constant of the type witness
Source§

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

Source§

const TYPE_EQ: TypeEq<T, <T as Identity>::Type> = TypeEq::NEW

Proof that Self is the same type as Self::Type, provides methods for casting between Self and Self::Type.
Source§

type Type = T

The same type as Self, used to emulate type equality bounds (T == U) with associated type equality constraints (T: Identity<Type = U>).
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> IntoResult<T> for T

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.