Skip to main content

Packet

Struct Packet 

Source
pub struct Packet<'a> {
    pub a: &'a [u8],
    pub b: &'a [u8],
}
Expand description

A borrowed view of a single packet from the ring buffer.

Because a packet’s payload may wrap across the end of the backing array, it is represented as two contiguous slices. a is the first (or only) part of the payload; b is the second part and is empty when the payload is contiguous.

Use Self::copy_into or Self::copy_part_into to copy the payload into a flat buffer.

Fields§

§a: &'a [u8]

First (or only) slice of the packet payload.

§b: &'a [u8]

Second slice of the packet payload; empty when the payload is contiguous.

Implementations§

Source§

impl<'a> Packet<'a>

Source

pub fn len(&self) -> usize

Returns the total length of the packet payload (a.len() + b.len()).

Source

pub fn is_empty(&self) -> bool

Returns true if the packet payload is empty.

Source

pub fn copy_into(&self, buffer: &mut [u8])

Copies the full packet payload into buffer.

§Panics

Panics if buffer.len() != self.a.len() + self.b.len().

Source

pub fn copy_part_into(&self, range: impl RangeBounds<usize>, buffer: &mut [u8])

Copies the bytes in range of the packet payload into buffer.

The range is interpreted over the logical concatenation [a | b]. Any type implementing RangeBounds<usize> is accepted, including 0..4, 2..=5, 1.., ..3, and ...

§Panics

Panics if buffer.len() does not equal the length implied by range, or if the resolved range end exceeds self.a.len() + self.b.len().

Source

pub fn extend_into<E: Extend<u8>>(&self, target: &mut E)

Extends target with the full packet payload.

Appends the bytes from a followed by b to target. Works with any collection that implements Extend<u8>, such as Vec<u8> or heapless::Vec<u8, N>.

Trait Implementations§

Source§

impl<'a> Debug for Packet<'a>

Source§

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

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

impl<'a> PartialEq for Packet<'a>

Source§

fn eq(&self, other: &Packet<'a>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<'a> StructuralPartialEq for Packet<'a>

Auto Trait Implementations§

§

impl<'a> Freeze for Packet<'a>

§

impl<'a> RefUnwindSafe for Packet<'a>

§

impl<'a> Send for Packet<'a>

§

impl<'a> Sync for Packet<'a>

§

impl<'a> Unpin for Packet<'a>

§

impl<'a> UnsafeUnpin for Packet<'a>

§

impl<'a> UnwindSafe for Packet<'a>

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