Struct wasm_timer::Delay
source · pub struct Delay { /* private fields */ }
Expand description
A future representing the notification that an elapsed duration has occurred.
This is created through the Delay::new
or Delay::new_at
methods
indicating when the future should fire at. Note that these futures are not
intended for high resolution timers, but rather they will likely fire some
granularity after the exact instant that they’re otherwise indicated to
fire at.
Implementations§
source§impl Delay
impl Delay
sourcepub fn new(dur: Duration) -> Delay ⓘ
pub fn new(dur: Duration) -> Delay ⓘ
Creates a new future which will fire at dur
time into the future.
The returned object will be bound to the default timer for this thread. The default timer will be spun up in a helper thread on first use.
sourcepub fn new_at(at: Instant) -> Delay ⓘ
pub fn new_at(at: Instant) -> Delay ⓘ
Creates a new future which will fire at the time specified by at
.
The returned object will be bound to the default timer for this thread. The default timer will be spun up in a helper thread on first use.
sourcepub fn new_handle(at: Instant, handle: TimerHandle) -> Delay ⓘ
pub fn new_handle(at: Instant, handle: TimerHandle) -> Delay ⓘ
Creates a new future which will fire at the time specified by at
.
The returned instance of Delay
will be bound to the timer specified by
the handle
argument.
sourcepub fn reset(&mut self, dur: Duration)
pub fn reset(&mut self, dur: Duration)
Resets this timeout to an new timeout which will fire at the time
specified by dur
.
This is equivalent to calling reset_at
with Instant::now() + dur
sourcepub fn reset_at(&mut self, at: Instant)
pub fn reset_at(&mut self, at: Instant)
Resets this timeout to an new timeout which will fire at the time
specified by at
.
This method is usable even of this instance of Delay
has “already
fired”. That is, if this future has resovled, calling this method means
that the future will still re-resolve at the specified instant.
If at
is in the past then this future will immediately be resolved
(when poll
is called).
Note that if any task is currently blocked on this future then that task
will be dropped. It is required to call poll
again after this method
has been called to ensure tha ta task is blocked on this future.
Trait Implementations§
Auto Trait Implementations§
impl !RefUnwindSafe for Delay
impl Send for Delay
impl Sync for Delay
impl Unpin for Delay
impl !UnwindSafe for Delay
Blanket Implementations§
source§impl<T> FutureExt for Twhere
T: Future + ?Sized,
impl<T> FutureExt for Twhere
T: Future + ?Sized,
source§fn map<U, F>(self, f: F) -> Map<Self, F>where
F: FnOnce(Self::Output) -> U,
Self: Sized,
fn map<U, F>(self, f: F) -> Map<Self, F>where
F: FnOnce(Self::Output) -> U,
Self: Sized,
source§fn map_into<U>(self) -> MapInto<Self, U>where
Self::Output: Into<U>,
Self: Sized,
fn map_into<U>(self) -> MapInto<Self, U>where
Self::Output: Into<U>,
Self: Sized,
source§fn then<Fut, F>(self, f: F) -> Then<Self, Fut, F>where
F: FnOnce(Self::Output) -> Fut,
Fut: Future,
Self: Sized,
fn then<Fut, F>(self, f: F) -> Then<Self, Fut, F>where
F: FnOnce(Self::Output) -> Fut,
Fut: Future,
Self: Sized,
f
. Read moresource§fn left_future<B>(self) -> Either<Self, B>where
B: Future<Output = Self::Output>,
Self: Sized,
fn left_future<B>(self) -> Either<Self, B>where
B: Future<Output = Self::Output>,
Self: Sized,
source§fn right_future<A>(self) -> Either<A, Self>where
A: Future<Output = Self::Output>,
Self: Sized,
fn right_future<A>(self) -> Either<A, Self>where
A: Future<Output = Self::Output>,
Self: Sized,
source§fn into_stream(self) -> IntoStream<Self>where
Self: Sized,
fn into_stream(self) -> IntoStream<Self>where
Self: Sized,
source§fn flatten(self) -> Flatten<Self>where
Self::Output: Future,
Self: Sized,
fn flatten(self) -> Flatten<Self>where
Self::Output: Future,
Self: Sized,
source§fn flatten_stream(self) -> FlattenStream<Self>where
Self::Output: Stream,
Self: Sized,
fn flatten_stream(self) -> FlattenStream<Self>where
Self::Output: Stream,
Self: Sized,
source§fn fuse(self) -> Fuse<Self>where
Self: Sized,
fn fuse(self) -> Fuse<Self>where
Self: Sized,
poll
will never again be called once it has
completed. This method can be used to turn any Future
into a
FusedFuture
. Read moresource§fn inspect<F>(self, f: F) -> Inspect<Self, F>where
F: FnOnce(&Self::Output),
Self: Sized,
fn inspect<F>(self, f: F) -> Inspect<Self, F>where
F: FnOnce(&Self::Output),
Self: Sized,
source§fn catch_unwind(self) -> CatchUnwind<Self>where
Self: Sized + UnwindSafe,
fn catch_unwind(self) -> CatchUnwind<Self>where
Self: Sized + UnwindSafe,
source§fn remote_handle(self) -> (Remote<Self>, RemoteHandle<Self::Output>)where
Self: Sized,
fn remote_handle(self) -> (Remote<Self>, RemoteHandle<Self::Output>)where
Self: Sized,
()
on completion and sends
its output to another future on a separate task. Read more