pub struct DataView<T> {
pub data: T,
pub offset: usize,
}Expand description
This struct represents a data view for reading and writing data in a byte array. When read/write, This increment current offset by the size of the value.
Fields
data: Toffset: usizeImplementations
sourceimpl<T: AsRef<[u8]>> DataView<T>
impl<T: AsRef<[u8]>> DataView<T>
sourcepub fn remaining_slice(&self) -> &[u8]
pub fn remaining_slice(&self) -> &[u8]
Returns remaining slice from the current offset. It doesn’t change the offset.
Examples
use data_view::DataView;
let mut view = DataView::from([1, 2, 3]);
assert_eq!(view.remaining_slice(), &[1, 2, 3]);
view.offset = 3;
assert!(view.remaining_slice().is_empty());sourcepub fn read<E: Endian>(&mut self) -> Option<E>
pub fn read<E: Endian>(&mut self) -> Option<E>
Reads a value of type E: Endian from the DataView.
Examples
use data_view::DataView;
let mut view = DataView::from([0; 4]);
view.write::<u16>(42);
view.offset = 0;
assert_eq!(view.read::<u16>().unwrap(), 42);sourcepub unsafe fn read_unchecked<E: Endian>(&mut self) -> E
pub unsafe fn read_unchecked<E: Endian>(&mut self) -> E
sourcepub fn read_slice(&mut self, len: usize) -> Option<&[u8]>
pub fn read_slice(&mut self, len: usize) -> Option<&[u8]>
Read slice from the current offset.
Example
use data_view::DataView;
let mut view = DataView::from([1, 2, 3, 4]);
assert_eq!(view.read_slice(2).unwrap(), &[1, 2]);
assert_eq!(view.read_slice(2).unwrap(), &[3, 4]);sourcepub unsafe fn read_slice_unchecked(&mut self, len: usize) -> &[u8]
pub unsafe fn read_slice_unchecked(&mut self, len: usize) -> &[u8]
Read slice from the current offset, without doing bounds checking.
For a safe alternative see read_slice.
Example
use data_view::DataView;
let mut view = DataView::from([1, 2, 3, 4]);
unsafe {
assert_eq!(view.read_slice_unchecked(2), &[1, 2]);
assert_eq!(view.read_slice_unchecked(2), &[3, 4]);
}Safety
Calling this method with an out-of-bounds index is [undefined behavior] even if the resulting reference is not used.
sourcepub fn read_buf<const N: usize>(&mut self) -> Option<[u8; N]>
pub fn read_buf<const N: usize>(&mut self) -> Option<[u8; N]>
Create a buffer and returns it, from the current offset.
Examples
use data_view::DataView;
let mut view = DataView::from([1, 2, 3, 4]);
assert_eq!(view.read_buf::<2>().unwrap(), [1, 2]);
assert_eq!(view.read_buf::<2>().unwrap(), [3, 4]);sourceimpl<T: AsMut<[u8]>> DataView<T>
impl<T: AsMut<[u8]>> DataView<T>
Trait Implementations
impl<T: Eq> Eq for DataView<T>
impl<T> StructuralEq for DataView<T>
impl<T> StructuralPartialEq for DataView<T>
Auto Trait Implementations
impl<T> RefUnwindSafe for DataView<T> where
T: RefUnwindSafe,
impl<T> Send for DataView<T> where
T: Send,
impl<T> Sync for DataView<T> where
T: Sync,
impl<T> Unpin for DataView<T> where
T: Unpin,
impl<T> UnwindSafe for DataView<T> where
T: UnwindSafe,
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more