Struct elfo::time::Delay

source ·
pub struct Delay<M> { /* private fields */ }
Expand description

A source that emits a message after some specified time.

Tracing

The emitted message continues the current trace.

Example

use elfo::time::Delay;

#[message]
struct MyTick;

while let Some(envelope) = ctx.recv().await {
    msg!(match envelope {
        SomeEvent => {
            ctx.attach(Delay::new(ctx.config().delay, MyTick));
        },
        MyTick => {
            tracing::info!("tick!");
        },
    });
}

Implementations§

source§

impl<M> Delay<M>where M: Message,

source

pub fn new(delay: Duration, message: M) -> UnattachedSource<Delay<M>>

Schedules the timer to emit the provided message after delay.

Creates an unattached instance of Delay.

source

pub fn until(when: Instant, message: M) -> UnattachedSource<Delay<M>>

Schedules the timer to emit the provided message at when.

Creates an unattached instance of Delay.

Stability

This method is unstable, because it accepts [tokio::time::Instant], which will be replaced in the future to support other runtimes.

Availability

This API is marked as unstable and is only available when the unstable crate feature is enabled. This comes with no stability guarantees, and could be changed or removed at any time.

Trait Implementations§

source§

impl<M> SourceHandle for Delay<M>where M: Message,

source§

fn is_terminated(&self) -> bool

Returns true if the source has stopped producing messages.
source§

fn terminate(self)

Terminates the source. Drop is called immediately.

Auto Trait Implementations§

§

impl<M> !RefUnwindSafe for Delay<M>

§

impl<M> Send for Delay<M>where M: Send,

§

impl<M> Sync for Delay<M>where M: Sync,

§

impl<M> !Unpin for Delay<M>

§

impl<M> !UnwindSafe for Delay<M>

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for Twhere 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.

§

impl<T> Pointable for T

§

const ALIGN: usize = mem::align_of::<T>()

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

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

§

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 Twhere U: TryFrom<T>,

§

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<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more