timeq

Struct QuadWheelWithOverflow

pub struct QuadWheelWithOverflow<EntryType>
where EntryType: Debug,
{ /* private fields */ }
Expand description

An implementation of four-level byte-sized wheel

Any value scheduled so far off that it doesn’t fit into the wheel is stored in an overflow Vec and added to the wheel, once time as advanced enough that it actually fits. In this design the maximum schedule duration for the wheel itself is u32::MAX units (typically ms), everything else goes into the overflow Vec.

Implementations§

§

impl<EntryType> QuadWheelWithOverflow<EntryType>
where EntryType: TimerEntryWithDelay,

pub fn insert(&mut self, e: EntryType) -> Result<(), TimerError<EntryType>>

Insert a new timeout into the wheel

§

impl<EntryType> QuadWheelWithOverflow<EntryType>
where EntryType: Debug,

pub fn new( pruner: fn(_: &EntryType) -> PruneDecision, ) -> QuadWheelWithOverflow<EntryType>

Create a new wheel

pub fn remaining_time_in_cycle(&self) -> u64

Described how many ticks are left before the timer has wrapped around completely

pub fn current_time_in_cycle(&self) -> u32

Produces a 32-bit timestamp including the current index of every wheel

pub fn insert_with_delay( &mut self, e: EntryType, delay: Duration, ) -> Result<(), TimerError<EntryType>>

Insert a new timeout into the wheel to be returned after delay ticks

pub fn tick(&mut self) -> Vec<EntryType>

Move the wheel forward by a single unit (ms)

Returns a list of all timers that expire during this tick.

pub fn skip(&mut self, amount: u32)

Skip a certain amount of units (ms)

No timers will be executed for the skipped time. Only use this after determining that it’s actually valid with can_skip!

pub fn can_skip(&self) -> Skip

Determine if and how many ticks can be skipped

Trait Implementations§

§

impl<EntryType> Default for QuadWheelWithOverflow<EntryType>
where EntryType: Debug,

§

fn default() -> QuadWheelWithOverflow<EntryType>

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl<EntryType> Freeze for QuadWheelWithOverflow<EntryType>

§

impl<EntryType> RefUnwindSafe for QuadWheelWithOverflow<EntryType>
where EntryType: RefUnwindSafe,

§

impl<EntryType> Send for QuadWheelWithOverflow<EntryType>
where EntryType: Send,

§

impl<EntryType> Sync for QuadWheelWithOverflow<EntryType>
where EntryType: Sync,

§

impl<EntryType> Unpin for QuadWheelWithOverflow<EntryType>
where EntryType: Unpin,

§

impl<EntryType> UnwindSafe for QuadWheelWithOverflow<EntryType>
where EntryType: UnwindSafe,

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> 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, 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.