pub struct MemWordWriterSlice<W: UnsignedInt, B: AsMut<[W]>> { /* private fields */ }
Expand description

An implementation of WordRead, WordWrite, and WordSeek for a mutable slice.

Writing beyond the end of the slice will return an error.

Example

use dsi_bitstream::prelude::*;

let mut words: [u64; 2] = [
    0x0043b59fcdf16077,
    0x702863e6f9739b86,
];

let mut word_writer = MemWordWriterSlice::new(&mut words);

// the stream is read sequentially
assert_eq!(word_writer.get_word_pos().unwrap(), 0);
assert_eq!(word_writer.read_word().unwrap(), 0x0043b59fcdf16077);
assert_eq!(word_writer.get_word_pos().unwrap(), 1);
assert_eq!(word_writer.read_word().unwrap(), 0x702863e6f9739b86);
assert_eq!(word_writer.get_word_pos().unwrap(), 2);
assert!(word_writer.read_word().is_err());

// you can change position
assert!(word_writer.set_word_pos(1).is_ok());
assert_eq!(word_writer.get_word_pos().unwrap(), 1);
assert_eq!(word_writer.read_word().unwrap(), 0x702863e6f9739b86);

// errored set position doesn't change the current position
assert_eq!(word_writer.get_word_pos().unwrap(), 2);
assert!(word_writer.set_word_pos(100).is_err());
assert_eq!(word_writer.get_word_pos().unwrap(), 2);

// we can write and read back!
assert!(word_writer.set_word_pos(0).is_ok());
assert!(word_writer.write_word(0x0b801b2bf696e8d2).is_ok());
assert_eq!(word_writer.get_word_pos().unwrap(), 1);
assert!(word_writer.set_word_pos(0).is_ok());
assert_eq!(word_writer.read_word().unwrap(), 0x0b801b2bf696e8d2);
assert_eq!(word_writer.get_word_pos().unwrap(), 1);

Implementations§

source§

impl<W: UnsignedInt, B: AsMut<[W]> + AsRef<[W]>> MemWordWriterSlice<W, B>

source

pub fn new(data: B) -> Self

Create a new MemWordWriterSlice from a slice of ZERO INITIALIZED data

source

pub fn len(&self) -> usize

source

pub fn is_empty(&self) -> bool

Trait Implementations§

source§

impl<W: Debug + UnsignedInt, B: Debug + AsMut<[W]>> Debug for MemWordWriterSlice<W, B>

source§

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

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

impl<W: PartialEq + UnsignedInt, B: PartialEq + AsMut<[W]>> PartialEq for MemWordWriterSlice<W, B>

source§

fn eq(&self, other: &MemWordWriterSlice<W, B>) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

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

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<W: UnsignedInt, B: AsMut<[W]>> WordRead for MemWordWriterSlice<W, B>

§

type Error = Error

§

type Word = W

The word type (the type of the result of WordRead::read_word).
source§

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

Read a word and advance the current position.
source§

impl<W: UnsignedInt, B: AsRef<[W]> + AsMut<[W]>> WordSeek for MemWordWriterSlice<W, B>

§

type Error = Error

source§

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

Get the current position in words from the start of the file.
source§

fn set_word_pos(&mut self, word_index: u64) -> Result<(), Error>

Set the current position in words from the start of the file to word_pos.
source§

impl<W: UnsignedInt, B: AsMut<[W]>> WordWrite for MemWordWriterSlice<W, B>

§

type Error = Error

§

type Word = W

The word type (the type of the argument of WordWrite::write_word).
source§

fn write_word(&mut self, word: W) -> Result<(), Error>

Write a word and advance the current position.
source§

impl<W: UnsignedInt, B: AsMut<[W]>> StructuralPartialEq for MemWordWriterSlice<W, B>

Auto Trait Implementations§

§

impl<W, B> RefUnwindSafe for MemWordWriterSlice<W, B>

§

impl<W, B> Send for MemWordWriterSlice<W, B>
where B: Send,

§

impl<W, B> Sync for MemWordWriterSlice<W, B>
where B: Sync,

§

impl<W, B> Unpin for MemWordWriterSlice<W, B>
where B: Unpin, W: Unpin,

§

impl<W, B> UnwindSafe for MemWordWriterSlice<W, B>
where B: UnwindSafe, W: UnwindSafe,

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> CastableFrom<T> for T

source§

fn cast_from(value: T) -> T

Call Self as W
source§

impl<T, U> CastableInto<U> for T
where U: CastableFrom<T>,

source§

fn cast(self) -> U

Call W::cast_from(self)
source§

impl<T> DowncastableFrom<T> for T

source§

fn downcast_from(value: T) -> T

Truncate the current UnsignedInt to a possibly smaller size
source§

impl<T, U> DowncastableInto<U> for T
where U: DowncastableFrom<T>,

source§

fn downcast(self) -> U

Call W::downcast_from(self)
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> Splat<T> for T

source§

fn splat(value: T) -> T

source§

impl<T> To<T> for T

source§

fn to(self) -> T

source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

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

§

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<T> UpcastableFrom<T> for T

source§

fn upcast_from(value: T) -> T

Extend the current UnsignedInt to a possibly bigger size.
source§

impl<T, U> UpcastableInto<U> for T
where U: UpcastableFrom<T>,

source§

fn upcast(self) -> U

Call W::upcast_from(self)