MemWriter

Struct MemWriter 

Source
pub struct MemWriter {
    pub data: Vec<u8>,
    pub pos: usize,
}
Expand description

A memory writer that can write data to a vector of bytes.

Fields§

§data: Vec<u8>

The data to write to.

§pos: usize

The current position in the data.

Implementations§

Source§

impl MemWriter

Source

pub fn new() -> Self

Creates a new MemWriter with an empty data vector.

Source

pub fn from_vec(data: Vec<u8>) -> Self

Creates a new MemWriter with the given data.

Source

pub fn into_inner(self) -> Vec<u8>

Returns the inner data of the writer.

Source

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

Returns a reference to the inner data of the writer.

Source

pub fn to_ref<'a>(&'a self) -> MemReaderRef<'a>

Returns a new MemReaderRef that references the current data and position.

Trait Implementations§

Source§

impl CPeek for MemWriter

Source§

fn cpeek(&self, buf: &mut [u8]) -> Result<usize>

Peeks data from the reader into the provided buffer. Returns the number of bytes read.
Source§

fn cpeek_at(&self, offset: u64, buf: &mut [u8]) -> Result<usize>

Peeks data from the reader at a specific offset into the provided buffer. Returns the number of bytes read.
Source§

fn cpeek_cstring(&self) -> Result<CString>

Peeks a C-style string (null-terminated) from the reader.
Source§

fn cpeek_u16string(&self) -> Result<Vec<u8>>

Peeks a UTF-16 string (null-terminated) from the reader. Returns the raw bytes of the UTF-16 string. (Null terminator is not included)
Source§

fn cpeek_exact(&self, buf: &mut [u8]) -> Result<()>

Peeks data from the reader into the provided buffer. Returns an error if the buffer is not filled completely.
Source§

fn cpeek_exact_at(&self, offset: u64, buf: &mut [u8]) -> Result<()>

Peeks data from the reader at a specific offset into the provided buffer. Returns an error if the buffer is not filled completely.
Source§

fn cpeek_at_vec(&self, offset: u64, len: usize) -> Result<Vec<u8>>

Peeks data from the reader at a specific offset into a vector. Returns the vector containing the data read.
Source§

fn cpeek_exact_at_vec(&self, offset: u64, len: usize) -> Result<Vec<u8>>

Peeks data from the reader at a specific offset into a vector. Returns an error if the buffer is not filled completely.
Source§

fn cpeek_u8(&self) -> Result<u8>

Peeks a u8 from the reader.
Source§

fn cpeek_u16(&self) -> Result<u16>

Peeks a u16 from the reader in little-endian order.
Source§

fn cpeek_u16_be(&self) -> Result<u16>

Peeks a u16 from the reader in big-endian order.
Source§

fn cpeek_u32(&self) -> Result<u32>

Peeks a u32 from the reader in little-endian order.
Source§

fn cpeek_u32_be(&self) -> Result<u32>

Peeks a u32 from the reader in big-endian order.
Source§

fn cpeek_u64(&self) -> Result<u64>

Peeks a u64 from the reader in little-endian order.
Source§

fn cpeek_u64_be(&self) -> Result<u64>

Peeks a u64 from the reader in big-endian order.
Source§

fn cpeek_u128(&self) -> Result<u128>

Peeks a u128 from the reader in little-endian order.
Source§

fn cpeek_u128_be(&self) -> Result<u128>

Peeks a u128 from the reader in big-endian order.
Source§

fn cpeek_i8(&self) -> Result<i8>

Peeks an i8 from the reader.
Source§

fn cpeek_i16(&self) -> Result<i16>

Peeks an i16 from the reader in little-endian order.
Source§

fn cpeek_i16_be(&self) -> Result<i16>

Peeks an i16 from the reader in big-endian order.
Source§

fn cpeek_i32(&self) -> Result<i32>

Peeks an i32 from the reader in little-endian order.
Source§

fn cpeek_i32_be(&self) -> Result<i32>

Peeks an i32 from the reader in big-endian order.
Source§

fn cpeek_i64(&self) -> Result<i64>

Peeks an i64 from the reader in little-endian order.
Source§

fn cpeek_i64_be(&self) -> Result<i64>

Peeks an i64 from the reader in big-endian order.
Source§

fn cpeek_i128(&self) -> Result<i128>

Peeks an i128 from the reader in little-endian order.
Source§

fn cpeek_i128_be(&self) -> Result<i128>

Peeks an i128 from the reader in big-endian order.
Source§

fn cpeek_u8_at(&self, offset: u64) -> Result<u8>

Peeks a u8 at a specific offset from the reader.
Source§

fn cpeek_u16_at(&self, offset: u64) -> Result<u16>

Peeks a u16 at a specific offset from the reader in little-endian order.
Source§

fn cpeek_u16_be_at(&self, offset: u64) -> Result<u16>

Peeks a u16 at a specific offset from the reader in big-endian order.
Source§

fn cpeek_u32_at(&self, offset: u64) -> Result<u32>

Peeks a u32 at a specific offset from the reader in little-endian order.
Source§

fn cpeek_u32_be_at(&self, offset: u64) -> Result<u32>

Peeks a u32 at a specific offset from the reader in big-endian order.
Source§

fn cpeek_u64_at(&self, offset: u64) -> Result<u64>

Peeks a u64 at a specific offset from the reader in little-endian order.
Source§

fn cpeek_u64_be_at(&self, offset: u64) -> Result<u64>

Peeks a u64 at a specific offset from the reader in big-endian order.
Source§

fn cpeek_u128_at(&self, offset: u64) -> Result<u128>

Peeks a u128 at a specific offset from the reader in little-endian order.
Source§

fn cpeek_u128_be_at(&self, offset: u64) -> Result<u128>

Peeks a u128 at a specific offset from the reader in big-endian order.
Source§

fn cpeek_i8_at(&self, offset: u64) -> Result<i8>

Peeks an i8 at a specific offset from the reader.
Source§

fn cpeek_i16_at(&self, offset: u64) -> Result<i16>

Peeks an i16 at a specific offset from the reader in little-endian order.
Source§

fn cpeek_i16_be_at(&self, offset: u64) -> Result<i16>

Peeks an i16 at a specific offset from the reader in big-endian order.
Source§

fn cpeek_i32_at(&self, offset: u64) -> Result<i32>

Peeks an i32 at a specific offset from the reader in little-endian order.
Source§

fn cpeek_i32_be_at(&self, offset: u64) -> Result<i32>

Peeks an i32 at a specific offset from the reader in big-endian order.
Source§

fn cpeek_i64_at(&self, offset: u64) -> Result<i64>

Peeks an i64 at a specific offset from the reader in little-endian order.
Source§

fn cpeek_i64_be_at(&self, offset: u64) -> Result<i64>

Peeks an i64 at a specific offset from the reader in big-endian order.
Source§

fn cpeek_i128_at(&self, offset: u64) -> Result<i128>

Peeks an i128 at a specific offset from the reader in little-endian order.
Source§

fn cpeek_i128_be_at(&self, offset: u64) -> Result<i128>

Peeks an i128 at a specific offset from the reader in big-endian order.
Source§

fn cpeek_cstring_at(&self, offset: u64) -> Result<CString>

Peeks a C-style string (null-terminated) from the reader at a specific offset.
Source§

fn cpeek_fstring( &self, len: usize, encoding: Encoding, trim: bool, ) -> Result<String>

Peeks a fixed-length string from the reader.
Source§

fn cpeek_fstring_at( &self, offset: u64, len: usize, encoding: Encoding, trim: bool, ) -> Result<String>

Peeks a fixed-length string from the reader at a specific offset.
Source§

fn cpeek_u16string_at(&self, offset: u64) -> Result<Vec<u8>>

Peeks a UTF-16 string (null-terminated) from the reader at a specific offset. Returns the raw bytes of the UTF-16 string. (Null terminator is not
Source§

fn cpeek_and_equal(&self, data: &[u8]) -> Result<()>

Peeks data and checks if it matches the provided data.
Source§

fn cpeek_and_equal_at(&self, offset: u64, data: &[u8]) -> Result<()>

Peeks data at a specific offset and checks if it matches the provided data.
Source§

impl CustomFn for MemWriter

Available on crate feature cat-system only.
Source§

fn write_patched_string(&mut self, s: &CstString, data: &[u8]) -> Result<usize>

Source§

impl Debug for MemWriter

Source§

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

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

impl Seek for MemWriter

Source§

fn seek(&mut self, pos: SeekFrom) -> Result<u64>

Seeks to a new position in the writer. If the new position is beyond the current length of the data, the data is resized when writing. (This means that seeking beyond the end does not immediately resize the data.)

Source§

fn stream_position(&mut self) -> Result<u64>

Returns the current seek position from the start of the stream. Read more
Source§

fn rewind(&mut self) -> Result<()>

Rewind to the beginning of a stream. Read more
Source§

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

🔬This is a nightly-only experimental API. (seek_stream_len)
Returns the length of this stream (in bytes). Read more
1.80.0 · Source§

fn seek_relative(&mut self, offset: i64) -> Result<(), Error>

Seeks relative to the current position. Read more
Source§

impl Write for MemWriter

Source§

fn write(&mut self, buf: &[u8]) -> Result<usize>

Writes a buffer into this writer, returning how many bytes were written. Read more
Source§

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

Flushes this output stream, ensuring that all intermediately buffered contents reach their destination. Read more
1.36.0 · Source§

fn write_vectored(&mut self, bufs: &[IoSlice<'_>]) -> Result<usize, Error>

Like write, except that it writes from a slice of buffers. Read more
Source§

fn is_write_vectored(&self) -> bool

🔬This is a nightly-only experimental API. (can_vector)
Determines if this Writer has an efficient write_vectored implementation. Read more
1.0.0 · Source§

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

Attempts to write an entire buffer into this writer. Read more
Source§

fn write_all_vectored(&mut self, bufs: &mut [IoSlice<'_>]) -> Result<(), Error>

🔬This is a nightly-only experimental API. (write_all_vectored)
Attempts to write multiple buffers into this writer. Read more
1.0.0 · Source§

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

Writes a formatted string into this writer, returning any error encountered. Read more
1.0.0 · Source§

fn by_ref(&mut self) -> &mut Self
where Self: Sized,

Creates a “by reference” adapter for this instance of Write. Read more

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

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> SeekExt for T
where T: Seek,

Source§

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

Returns the length of the stream.
Source§

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

Aligns the current position to the given alignment. Returns the new position after alignment.
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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WriteAt for T
where T: Write + Seek,

Source§

fn write_at(&mut self, offset: u64, buf: &[u8]) -> Result<usize, Error>

Writes data to the writer at a specific offset. Returns the number of bytes written.
Source§

fn write_all_at(&mut self, offset: u64, buf: &[u8]) -> Result<(), Error>

Writes all data to the writer at a specific offset. Returns an error if the write fails.
Source§

fn write_u8_at(&mut self, offset: u64, value: u8) -> Result<()>

Writes a u8 at a specific offset.
Source§

fn write_u16_at(&mut self, offset: u64, value: u16) -> Result<()>

Writes a u16 at a specific offset in little-endian order.
Source§

fn write_u16_be_at(&mut self, offset: u64, value: u16) -> Result<()>

Writes a u16 at a specific offset in big-endian order.
Source§

fn write_u32_at(&mut self, offset: u64, value: u32) -> Result<()>

Writes a u32 at a specific offset in little-endian order.
Source§

fn write_u32_be_at(&mut self, offset: u64, value: u32) -> Result<()>

Writes a u32 at a specific offset in big-endian order.
Source§

fn write_u64_at(&mut self, offset: u64, value: u64) -> Result<()>

Writes a u64 at a specific offset in little-endian order.
Source§

fn write_u64_be_at(&mut self, offset: u64, value: u64) -> Result<()>

Writes a u64 at a specific offset in big-endian order.
Source§

fn write_u128_at(&mut self, offset: u64, value: u128) -> Result<()>

Writes a u128 at a specific offset in little-endian order.
Source§

fn write_u128_be_at(&mut self, offset: u64, value: u128) -> Result<()>

Writes a u128 at a specific offset in big-endian order.
Source§

fn write_i8_at(&mut self, offset: u64, value: i8) -> Result<()>

Writes an i8 at a specific offset.
Source§

fn write_i16_at(&mut self, offset: u64, value: i16) -> Result<()>

Writes an i16 at a specific offset in little-endian order.
Source§

fn write_i16_be_at(&mut self, offset: u64, value: i16) -> Result<()>

Writes an i16 at a specific offset in big-endian order.
Source§

fn write_i32_at(&mut self, offset: u64, value: i32) -> Result<()>

Writes an i32 at a specific offset in little-endian order.
Source§

fn write_i32_be_at(&mut self, offset: u64, value: i32) -> Result<()>

Writes an i32 at a specific offset in big-endian order.
Source§

fn write_i64_at(&mut self, offset: u64, value: i64) -> Result<()>

Writes an i64 at a specific offset in little-endian order.
Source§

fn write_i64_be_at(&mut self, offset: u64, value: i64) -> Result<()>

Writes an i64 at a specific offset in big-endian order.
Source§

fn write_i128_at(&mut self, offset: u64, value: i128) -> Result<()>

Writes an i128 at a specific offset in little-endian order.
Source§

fn write_i128_be_at(&mut self, offset: u64, value: i128) -> Result<()>

Writes an i128 at a specific offset in big-endian order.
Source§

fn write_cstring_at(&mut self, offset: u64, value: &CString) -> Result<()>

Writes a C-style string (null-terminated) at a specific offset.
Source§

impl<W> WriteBytesExt for W
where W: Write + ?Sized,

Source§

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

Writes an unsigned 8 bit integer to the underlying writer. Read more
Source§

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

Writes a signed 8 bit integer to the underlying writer. Read more
Source§

fn write_u16<T>(&mut self, n: u16) -> Result<(), Error>
where T: ByteOrder,

Writes an unsigned 16 bit integer to the underlying writer. Read more
Source§

fn write_i16<T>(&mut self, n: i16) -> Result<(), Error>
where T: ByteOrder,

Writes a signed 16 bit integer to the underlying writer. Read more
Source§

fn write_u24<T>(&mut self, n: u32) -> Result<(), Error>
where T: ByteOrder,

Writes an unsigned 24 bit integer to the underlying writer. Read more
Source§

fn write_i24<T>(&mut self, n: i32) -> Result<(), Error>
where T: ByteOrder,

Writes a signed 24 bit integer to the underlying writer. Read more
Source§

fn write_u32<T>(&mut self, n: u32) -> Result<(), Error>
where T: ByteOrder,

Writes an unsigned 32 bit integer to the underlying writer. Read more
Source§

fn write_i32<T>(&mut self, n: i32) -> Result<(), Error>
where T: ByteOrder,

Writes a signed 32 bit integer to the underlying writer. Read more
Source§

fn write_u48<T>(&mut self, n: u64) -> Result<(), Error>
where T: ByteOrder,

Writes an unsigned 48 bit integer to the underlying writer. Read more
Source§

fn write_i48<T>(&mut self, n: i64) -> Result<(), Error>
where T: ByteOrder,

Writes a signed 48 bit integer to the underlying writer. Read more
Source§

fn write_u64<T>(&mut self, n: u64) -> Result<(), Error>
where T: ByteOrder,

Writes an unsigned 64 bit integer to the underlying writer. Read more
Source§

fn write_i64<T>(&mut self, n: i64) -> Result<(), Error>
where T: ByteOrder,

Writes a signed 64 bit integer to the underlying writer. Read more
Source§

fn write_u128<T>(&mut self, n: u128) -> Result<(), Error>
where T: ByteOrder,

Writes an unsigned 128 bit integer to the underlying writer.
Source§

fn write_i128<T>(&mut self, n: i128) -> Result<(), Error>
where T: ByteOrder,

Writes a signed 128 bit integer to the underlying writer.
Source§

fn write_uint<T>(&mut self, n: u64, nbytes: usize) -> Result<(), Error>
where T: ByteOrder,

Writes an unsigned n-bytes integer to the underlying writer. Read more
Source§

fn write_int<T>(&mut self, n: i64, nbytes: usize) -> Result<(), Error>
where T: ByteOrder,

Writes a signed n-bytes integer to the underlying writer. Read more
Source§

fn write_uint128<T>(&mut self, n: u128, nbytes: usize) -> Result<(), Error>
where T: ByteOrder,

Writes an unsigned n-bytes integer to the underlying writer. Read more
Source§

fn write_int128<T>(&mut self, n: i128, nbytes: usize) -> Result<(), Error>
where T: ByteOrder,

Writes a signed n-bytes integer to the underlying writer. Read more
Source§

fn write_f32<T>(&mut self, n: f32) -> Result<(), Error>
where T: ByteOrder,

Writes a IEEE754 single-precision (4 bytes) floating point number to the underlying writer. Read more
Source§

fn write_f64<T>(&mut self, n: f64) -> Result<(), Error>
where T: ByteOrder,

Writes a IEEE754 double-precision (8 bytes) floating point number to the underlying writer. Read more
Source§

impl<T> WriteExt for T
where T: Write,

Source§

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

Writes a u8 to the writer.
Source§

fn write_u16(&mut self, value: u16) -> Result<(), Error>

Writes a u16 to the writer in little-endian order.
Source§

fn write_u16_be(&mut self, value: u16) -> Result<(), Error>

Writes a u16 to the writer in big-endian order.
Source§

fn write_u32(&mut self, value: u32) -> Result<(), Error>

Writes a u32 to the writer in little-endian order.
Source§

fn write_u32_be(&mut self, value: u32) -> Result<(), Error>

Writes a u32 to the writer in big-endian order.
Source§

fn write_u64(&mut self, value: u64) -> Result<(), Error>

Writes a u64 to the writer in little-endian order.
Source§

fn write_u64_be(&mut self, value: u64) -> Result<(), Error>

Writes a u64 to the writer in big-endian order.
Source§

fn write_u128(&mut self, value: u128) -> Result<(), Error>

Writes a u128 to the writer in little-endian order.
Source§

fn write_u128_be(&mut self, value: u128) -> Result<(), Error>

Writes a u128 to the writer in big-endian order.
Source§

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

Writes an i8 to the writer.
Source§

fn write_i16(&mut self, value: i16) -> Result<(), Error>

Writes an i16 to the writer in little-endian order.
Source§

fn write_i16_be(&mut self, value: i16) -> Result<(), Error>

Writes an i16 to the writer in big-endian order.
Source§

fn write_i32(&mut self, value: i32) -> Result<(), Error>

Writes an i32 to the writer in little-endian order.
Source§

fn write_i32_be(&mut self, value: i32) -> Result<(), Error>

Writes an i32 to the writer in big-endian order.
Source§

fn write_i64(&mut self, value: i64) -> Result<(), Error>

Writes an i64 to the writer in little-endian order.
Source§

fn write_i64_be(&mut self, value: i64) -> Result<(), Error>

Writes an i64 to the writer in big-endian order.
Source§

fn write_i128(&mut self, value: i128) -> Result<(), Error>

Writes an i128 to the writer in little-endian order.
Source§

fn write_i128_be(&mut self, value: i128) -> Result<(), Error>

Writes an i128 to the writer in big-endian order.
Source§

fn write_cstring(&mut self, value: &CString) -> Result<(), Error>

Writes a C-style string (null-terminated) to the writer.
Source§

fn write_struct<V>( &mut self, value: &V, big: bool, encoding: Encoding, ) -> Result<(), Error>
where V: StructPack,

Write a struct to the writer.
Source§

impl<T> AnyDebug for T
where T: Debug + Any,

Source§

impl<T> ErasedDestructor for T
where T: 'static,

Source§

impl<T> WriteSeek for T
where T: Write + Seek,