Skip to main content

ApiString

Struct ApiString 

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

A string type used in VPP API messages.

This represents a variable-length string with a length prefix, commonly used in VPP API message structures.

Note that copying/cloning ApiString objects will not copy/clone the contents of the string.

Implementations§

Source§

impl ApiString

Source

pub const fn len(&self) -> u32

Returns the length of the string in bytes.

Source

pub const fn is_empty(&self) -> bool

Returns true if the string has a length of zero.

Source

pub fn as_bytes(&self) -> &[u8]

Returns a byte slice of the string’s contents.

Source

pub fn to_str(&self) -> Result<&str, Utf8Error>

Converts the string to a &str slice.

If the contents of the ApiString are valid UTF-8 data, this function will return the corresponding &[str] slice. Otherwise, it will return an error with details of where UTF-8 validation failed.

Source

pub fn to_string_lossy(&self) -> Cow<'_, str>

Converts the string to a Cow<str>, replacing invalid UTF-8 sequences with �.

Source

pub unsafe fn set_len(&mut self, length: u32)

Sets the length of the string in bytes.

§Safety

The caller must ensure that the underlying buffer has at least length bytes of valid memory and is initialised.

Source

pub fn copy_from_str(&mut self, s: &str)

Copies the contents of the given string into this ApiString.

§Panics

Panics if the length of the ApiString is different to the length of the string in bytes.

Trait Implementations§

Source§

impl Clone for ApiString

Source§

fn clone(&self) -> ApiString

Returns a duplicate 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 ApiString

Source§

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

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

impl Default for ApiString

Source§

fn default() -> ApiString

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

impl EndianSwap for ApiString

Source§

unsafe fn endian_swap(&mut self, _to_net: bool)

Swap the endianness of the message in-place. Read more
Source§

impl Copy for ApiString

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.