Struct hid_io_core::mailbox::Mailbox[][src]

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

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

impl Mailbox[src]

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

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

Attempt to locate an unused id for the device key

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

Add uid to lookup

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

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)

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

Register node as an endpoint (device or api)

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

Unregister node as an endpoint (device or api)

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

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

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

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

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

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

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

pub fn drop_all_subscribers(&self)[src]

Trait Implementations

impl Clone for Mailbox[src]

impl Debug for Mailbox[src]

impl Default for Mailbox[src]

Auto Trait Implementations

impl !RefUnwindSafe for Mailbox

impl Send for Mailbox

impl Sync for Mailbox

impl Unpin for Mailbox

impl !UnwindSafe for Mailbox

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> Same<T> for T[src]

type Output = T

Should always be Self

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

impl<V, T> VZip<V> for T where
    V: MultiLane<T>, 
[src]