Skip to main content

DeviceFriendlyNameFeature

Struct DeviceFriendlyNameFeature 

Source
pub struct DeviceFriendlyNameFeature { /* private fields */ }
Expand description

Implements the DeviceFriendlyName / 0x0007 feature.

Implementations§

Source§

impl DeviceFriendlyNameFeature

Source

pub async fn get_friendly_name_length( &self, ) -> Result<DeviceFriendlyNameLength, Hidpp20Error>

Retrieves the length data of the friendly device name feature.

Source

pub async fn get_friendly_name( &self, index: u8, ) -> Result<[u8; 15], Hidpp20Error>

Retrieves a chunk of characters of the friendly name of the device, starting at a specific index (inclusive).

This function will always retrieve 15 bytes, filling up the rest with zeroes if the chunk is shorter than that.

Use this function in conjunction with Self::get_friendly_name_length to retrieve the whole friendly name of the device.
A convenience wrapper implementing this functionality is provided as Self::get_whole_friendly_name.

Source

pub async fn get_whole_friendly_name(&self) -> Result<String, Hidpp20Error>

Retrieves the whole friendly name of the device by first calling Self::get_friendly_name_length once and then repeatedly calling Self::get_friendly_name until all characters were received.

Source

pub async fn get_default_friendly_name( &self, index: u8, ) -> Result<[u8; 15], Hidpp20Error>

Retrieves a chunk of characters of the default friendly name of the device, starting at a specific index (inclusive).

This function will always retrieve 15 bytes, filling up the rest with zeroes if the chunk is shorter than that.

Use this function in conjunction with Self::get_friendly_name_length to retrieve the whole default friendly name of the device.
A convenience wrapper implementing this functionality is provided as Self::get_whole_default_friendly_name.

Source

pub async fn get_whole_default_friendly_name( &self, ) -> Result<String, Hidpp20Error>

Retrieves the whole default friendly name of the device by first calling Self::get_friendly_name_length once and then repeatedly calling Self::get_default_friendly_name until all characters were received.

Source

pub async fn set_friendly_name( &self, index: u8, chunk: [u8; 15], ) -> Result<u8, Hidpp20Error>

Sets a chunk of the friendly device name, starting at a specific index (inclusive).

If the index and chunk combination would exceed the DeviceFriendlyNameLength::name_max_length, the name is automatically truncated by the device.

Returns the new total length of the friendly device name.

A convenience wrapper setting the whole friendly device name at once is provided as Self::set_whole_device_name.

Source

pub async fn set_whole_device_name( &self, name: String, ) -> Result<u8, Hidpp20Error>

Sets the whole friendly device name, truncating the value to a maximum of DeviceFriendlyNameLength::name_max_length bytes.

This method calls Self::get_friendly_name_length first to retrieve the maximum length and then repeatedly calls Self::set_friendly_name until the whole name is set.

Returns the total length of the name after setting it,

Source

pub async fn reset_friendly_name(&self) -> Result<u8, Hidpp20Error>

Resets the friendly device name to the default one.

Returns the total length of the name after resetting it,

Trait Implementations§

Source§

impl Clone for DeviceFriendlyNameFeature

Source§

fn clone(&self) -> DeviceFriendlyNameFeature

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

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

Performs copy-assignment from source. Read more
Source§

impl CreatableFeature for DeviceFriendlyNameFeature

Source§

const ID: u16 = 0x0007

The protocol ID of the implemented feature.
Source§

const STARTING_VERSION: u8 = 0

The version of the feature the implementation starts to support.
Source§

fn new(chan: Arc<HidppChannel>, device_index: u8, feature_index: u8) -> Self

Creates a new instance of the feature implementation.
Source§

impl Feature for DeviceFriendlyNameFeature

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