Struct Controller

Source
pub struct Controller<K, V, R>
where K: Sync + Send + Hash + Eq, V: Sync + Send + 'static, R: 'static,
{ /* private fields */ }
Expand description

The Controller is a non-producing handle to the scheduler. It allows creation of new channels as well as clearing of queues.

Implementations§

Source§

impl<K, V, R> Controller<K, V, R>
where K: Sync + Send + Hash + Eq, V: Sync + Send + 'static, R: 'static,

Source

pub fn channel(&self, key: K, bound: usize) -> Sender<V>

Create a new channel, returns the producer site. See below for bound. May block if clearing or scheduling tick is currently running.

§Bound

Is the next power of two for the handed value

Source

pub fn cancel_channel(&self, key: &K) -> Result<(), ()>

Clear queue for specific channel & running jobs if supported.

May block if channel is called or a schedule is running. Note that for a queue with bounds n, it has a O(n) worst case complexity.

Returns Err if the specified channel is invalid.

Source

pub fn gc(&self)

Manually trigger schedule. Normaly not required but if you should drop a lot of channels and don’t insert/complete a job in the next time, you may call this.

Source

pub fn set_worker_max(&self, max_workers: usize)

Change maximum amount of workers.
Takes effect on next schedule.

Source

pub fn get_worker_max(&self) -> usize

Returns currently set max amount of workers.

Trait Implementations§

Source§

impl<K, V, R> Clone for Controller<K, V, R>
where K: Sync + Send + Hash + Eq + Clone, V: Sync + Send + 'static + Clone, R: 'static + Clone,

Source§

fn clone(&self) -> Controller<K, V, R>

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

Auto Trait Implementations§

§

impl<K, V, R> Freeze for Controller<K, V, R>

§

impl<K, V, R> !RefUnwindSafe for Controller<K, V, R>

§

impl<K, V, R> Send for Controller<K, V, R>

§

impl<K, V, R> Sync for Controller<K, V, R>

§

impl<K, V, R> Unpin for Controller<K, V, R>

§

impl<K, V, R> !UnwindSafe for Controller<K, V, R>

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