hjul

Struct Timer

Source
pub struct Timer(/* private fields */);

Implementations§

Source§

impl Timer

Source

pub fn stop(&self)

Stop the timer (preventing execution of the callback in the future)

§Note

Another way to stop a timer is to drop every clone of the timer.

§Example
let timer = runner.timer(|| assert!(false));
timer.reset(Duration::from_millis(200));
timer.stop();

// callback is never executed
thread::sleep(Duration::from_millis(500));
Source

pub fn reset(&self, duration: Duration)

Restart the timer, regardless of whether the timer is running or not. e.g. repeatably calling .reset(1 sec) will cause the timer to never fire.

§Arguments
  • duration: duration until the callback should execute
§Example
let timer = runner.timer(|| assert!(false));

// the timer never fires
let dur = Duration::from_millis(200);
for _ in 0..5 {
    timer.reset(dur);
    thread::sleep(dur / 2);
}

// timer is dropped and cancelled
Source

pub fn start(&self, duration: Duration) -> bool

Start the timer, but only if the timer is not already pending e.g. if repeatably calling .start(1 sec), the timer will fire ~ once every second

§Arguments
  • duration: duration until the callback should execute
§Returns

A bool indicating whether the timer was started (true) or already running (false).

§Example
let timer = runner.timer(|| println!("fired"));

// this timer will fire twice
let dur = Duration::from_millis(200);
for _ in 0..5 {
    timer.start(dur);
    thread::sleep(dur / 2);
}

// timer is dropped and cancelled
Source

pub fn fire(&self)

Manually cause the timer to fire immediately. This cancels any pending timeout (equivalent to calling .stop()) before executing the callback.

§Note

The callback is run in the calling thread as oppose to being run by the thread in the associated Runner instance.

§Example
let timer = runner.timer(|| println!("fired"));

timer.start(Duration::from_millis(200));
timer.fire();

// timer is fired immediately, not after 200ms.

Trait Implementations§

Source§

impl Clone for Timer

Source§

fn clone(&self) -> Timer

Returns a copy of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for Timer

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl Freeze for Timer

§

impl !RefUnwindSafe for Timer

§

impl Send for Timer

§

impl Sync for Timer

§

impl Unpin for Timer

§

impl !UnwindSafe for Timer

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, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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> 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.