Struct Mailbox

Source
pub struct Mailbox {
    pub nodes: Arc<RwLock<Vec<Endpoint>>>,
    pub last_uid: Arc<RwLock<u64>>,
    pub lookup: Arc<RwLock<HashMap<String, Vec<u64>>>>,
    pub sender: Sender<Message>,
    pub ack_timeout: Arc<RwLock<Duration>>,
    pub rt: Arc<Runtime>,
}
Expand description

HID-IO Mailbox

Handles passing messages to various components inside of HID-IO Best thought of as a broadcast style packet switcher. Each thread (usually async tokio) is given a receiver and can filter for any desired packets. This is not quite as effecient as direct channels; however, this greatly simplifies message passing across HID-IO. Making it easier to add new modules.

This struct can be safely cloned and passed around anywhere in the codebase. In most cases only the sender field is used (as it has the subscribe() function as well).

Fields§

§nodes: Arc<RwLock<Vec<Endpoint>>>§last_uid: Arc<RwLock<u64>>§lookup: Arc<RwLock<HashMap<String, Vec<u64>>>>§sender: Sender<Message>§ack_timeout: Arc<RwLock<Duration>>§rt: Arc<Runtime>

Implementations§

Source§

impl Mailbox

Source

pub fn new(rt: Arc<Runtime>) -> Mailbox

Source

pub fn get_uid(&mut self, key: String, path: String) -> Option<u64>

Attempt to locate an unused id for the device key

Source

pub fn add_uid(&mut self, key: String, uid: u64)

Add uid to lookup

Source

pub fn assign_uid(&mut self, key: String, path: String) -> Result<u64, Error>

Assign uid This function will attempt to lookup an existing id first And generate a new uid if necessary An error is returned if this lookup already has a uid (string+path)

Source

pub fn register_node(&mut self, endpoint: Endpoint)

Register node as an endpoint (device or api)

Source

pub fn unregister_node(&mut self, uid: u64)

Unregister node as an endpoint (device or api)

Source

pub async fn send_command( &self, src: Address, dst: Address, id: HidIoCommandId, data: Vec<u8>, ack: bool, ) -> Result<Option<Message>, AckWaitError>

Convenience function to send a HidIo Command to device using the mailbox Returns the Ack message if enabled. Ack will timeout if it exceeds self.ack_timeout

Source

pub fn try_send_message( &self, msg: Message, ) -> Result<Option<Message>, CommandError>

Convenience function to send a HidIoPacketBuffer using the mailbox Returns the Ack message if available and applicable

Source

pub fn try_send_command( &self, src: Address, dst: Address, id: HidIoCommandId, data: Vec<u8>, ack: bool, ) -> Result<Option<Message>, AckWaitError>

Convenience function to send a HidIo Command to device using the mailbox Returns the Ack message if enabled. This is the blocking version of send_command(). Ack will timeout if it exceeds self.ack_timeout

Source

pub fn drop_subscriber(&self, uid: u64, sid: u64)

Source

pub fn drop_all_subscribers(&self)

Trait Implementations§

Source§

impl Clone for Mailbox

Source§

fn clone(&self) -> Mailbox

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 Mailbox

Source§

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

Formats the value using the given formatter. Read more
Source§

impl Default for Mailbox

Source§

fn default() -> Self

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

Auto Trait Implementations§

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> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
Source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V