Struct MutBitsArray

Source
pub struct MutBitsArray<'a, const N: usize> { /* private fields */ }
Expand description

This struct wraps a provided borrowed static array in a MutBits impl. Operates like a slice, walking through the array filling it up.

Implementations§

Source§

impl<'a, const N: usize> MutBitsArray<'a, N>

Source

pub fn new(arr: &'a mut [u8; N]) -> Self

Wraps the provided array, providing a MutBits impl

Source

pub fn len(&self) -> usize

Returns the current length of the written data.

Source

pub fn is_empty(&self) -> bool

Has anything been written?

Source

pub fn reset(&mut self)

Resets the writing position to zero. Does NOT clear the data.

Source

pub fn zero(&mut self)

Resets the writing position to zero and clears the data back to zeros. Same as calling fill(0)

Source

pub fn fill(&mut self, val: u8)

Fills the array with the value, resets the writing position back to zero.

Source

pub fn reader(&'a self) -> BitsArray<'a, N>

Get an Reader from this array, starts at the beginning and runs until the high water ‘pos’ mark returning a view into JUST the data written.

Trait Implementations§

Source§

impl<'a, const N: usize> From<&'a mut [u8; N]> for MutBitsArray<'a, N>

Source§

fn from(arr: &'a mut [u8; N]) -> Self

Converts to this type from the input type.
Source§

impl<const N: usize> MutBits for MutBitsArray<'_, N>

Source§

fn write_u8(&mut self, val: u8) -> Result<(), Error>

Writes a single u8
Source§

fn write_i8(&mut self, val: i8) -> Result<(), Error>

Writes a single i8
Source§

fn write_bool(&mut self, val: bool) -> Result<(), Error>

Writes 1u8 if true, 0u8 if false
Source§

fn write_be_utf8_char(&mut self, val: char) -> Result<usize, Error>

Encodes the character as UTF-8, and writes anywhere from 1-4 bytes. The number of bytes written is returned.
Source§

fn write_be_u16(&mut self, val: u16) -> Result<(), Error>

Writes a single u16 in big-endian order, 2 bytes, MSB first.
Source§

fn write_le_u16(&mut self, val: u16) -> Result<(), Error>

Writes a single u16 in little-endian order, 2 bytes, LSB first.
Source§

fn write_be_u32(&mut self, val: u32) -> Result<(), Error>

Writes a single u32 in big-endian order, 4 bytes, MSB first.
Source§

fn write_le_u32(&mut self, val: u32) -> Result<(), Error>

Writes a single u32 in little-endian order, 4 bytes, LSB first.
Source§

fn write_be_u64(&mut self, val: u64) -> Result<(), Error>

Writes a single u64 in big-endian order, 8 bytes, MSB first.
Source§

fn write_le_u64(&mut self, val: u64) -> Result<(), Error>

Writes a single u64 in little-endian order, 8 bytes, LSB first.
Source§

fn write_be_u128(&mut self, val: u128) -> Result<(), Error>

Writes a single u128 in big-endian order, 16 bytes, MSB first.
Source§

fn write_le_u128(&mut self, val: u128) -> Result<(), Error>

Writes a single u128 in little-endian order, 16 bytes, LSB first.
Source§

fn write_be_f32(&mut self, val: f32) -> Result<(), Error>

Writes a single f32 in standard IEEE754 format, 4 bytes
Source§

fn write_le_f32(&mut self, val: f32) -> Result<(), Error>

Writes a single f32 in reversed IEEE754 format, 4 bytes
Source§

fn write_be_f64(&mut self, val: f64) -> Result<(), Error>

Writes a single u16 in standard IEEE754 format, 8 bytes
Source§

fn write_le_f64(&mut self, val: f64) -> Result<(), Error>

Writes a single u16 in reversed IEEE754 format, 8 bytes
Source§

fn write_be_i16(&mut self, val: i16) -> Result<(), Error>

Writes a single i16 in big-endian order, 2 bytes, MSB first.
Source§

fn write_le_i16(&mut self, val: i16) -> Result<(), Error>

Writes a single i16 in little-endian order, 2 bytes, LSB first.
Source§

fn write_be_i32(&mut self, val: i32) -> Result<(), Error>

Writes a single i32 in big-endian order, 4 bytes, MSB first.
Source§

fn write_le_i32(&mut self, val: i32) -> Result<(), Error>

Writes a single i32 in little-endian order, 4 bytes, LSB first.
Source§

fn write_be_i64(&mut self, val: i64) -> Result<(), Error>

Writes a single i64 in big-endian order, 8 bytes, MSB first.
Source§

fn write_le_i64(&mut self, val: i64) -> Result<(), Error>

Writes a single i64 in little-endian order, 8 bytes, LSB first.
Source§

fn write_be_i128(&mut self, val: i128) -> Result<(), Error>

Writes a single i128 in big-endian order, 16 bytes, MSB first.
Source§

fn write_le_i128(&mut self, val: i128) -> Result<(), Error>

Writes a single i128 in little-endian order, 16 bytes, LSB first.
Source§

fn write_u8_blob(&mut self, val: &[u8]) -> Result<(), Error>

Writes a sized blob, a series of bytes preceded by a u8 declaring the size
Source§

fn write_be_u16_blob(&mut self, val: &[u8]) -> Result<(), Error>

Writes a sized blob, a series of bytes preceded by a u16 declaring the size
Source§

fn write_le_u16_blob(&mut self, val: &[u8]) -> Result<(), Error>

Writes a sized blob, a series of bytes preceded by a u16 declaring the size
Source§

fn write_be_u32_blob(&mut self, val: &[u8]) -> Result<(), Error>

Writes a sized blob, a series of bytes preceded by a u32 declaring the size
Source§

fn write_le_u32_blob(&mut self, val: &[u8]) -> Result<(), Error>

Writes a sized blob, a series of bytes preceded by a u32 declaring the size
Source§

fn write_be_u64_blob(&mut self, val: &[u8]) -> Result<(), Error>

Writes a sized blob, a series of bytes preceded by a u64 declaring the size
Source§

fn write_le_u64_blob(&mut self, val: &[u8]) -> Result<(), Error>

Writes a sized blob, a series of bytes preceded by a u64 declaring the size
Source§

fn write_all_bytes(&mut self, val: &[u8]) -> Result<(), Error>

Writes all the bytes in order
Source§

fn write_fmt_impl(&mut self, args: Arguments<'_>) -> Result<(), Error>

Available on crate feature alloc only.
Allows the use of core::format_args macro
Source§

fn write_some_bytes(&mut self, val: &[u8]) -> usize

Writes some subset of bytes until either the input is exhausted, or the underlying buffer fills up or errors. Returns the total number of bytes written
Source§

fn write_str_u32_blob(&mut self, val: &str) -> Result<usize, Error>

Writes a specific sized string from the stream, a string prefixed by a 4-byte big-endian length.
Source§

fn write_exact(&mut self, val: &[u8], len: usize) -> Result<(), Error>

Writes the exact amount of bytes from the input buffer to the output stream Returns an error if the buffer doesn’t have enough values or if the output stream errors.
Source§

fn write_all_into_self_from<T: Bits>( &mut self, other: &mut T, ) -> Result<u64, Error>

Copies all data from the other stream into this stream.
Source§

fn flush(&mut self) -> Result<(), Error>

Flush all bytes out of the cache. Most impl’s won’t need this.

Auto Trait Implementations§

§

impl<'a, const N: usize> Freeze for MutBitsArray<'a, N>

§

impl<'a, const N: usize> RefUnwindSafe for MutBitsArray<'a, N>

§

impl<'a, const N: usize> Send for MutBitsArray<'a, N>

§

impl<'a, const N: usize> Sync for MutBitsArray<'a, N>

§

impl<'a, const N: usize> Unpin for MutBitsArray<'a, N>

§

impl<'a, const N: usize> !UnwindSafe for MutBitsArray<'a, N>

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.