Struct io::ByteWriterWrapper

source ·
pub struct ByteWriterWrapper<RW: BlockReader + BlockWriter>(/* private fields */);
Expand description

A wrapper struct that implements a byte-wise writer atop a block-based reader and writer.

This is effectively the same struct as ByteReaderWriterWrapper, but it allows only writing to the underlying I/O stream, not reading.

See the ByteWriter trait docs for an explanation of why both BlockReader + BlockWriter are required.

Example

Use the From implementation around a BlockReader + BlockWriter instance, such as:

// Assume `storage_dev` implements `BlockReader + BlockWriter`
ByteReaderWriterWrapper::from(storage_dev).write_at(...);

Trait Implementations§

source§

impl<RW> BlockIo for ByteWriterWrapper<RW>where RW: BlockReader + BlockWriter,

source§

fn block_size(&self) -> usize

Returns the size in bytes of a single block (i.e., sector), the minimum granularity of I/O transfers.
source§

impl<RW> BlockWriter for ByteWriterWrapper<RW>where RW: BlockReader + BlockWriter,

source§

fn write_blocks( &mut self, buffer: &[u8], block_offset: usize ) -> Result<usize, IoError>

Writes blocks of data from the given buffer to this writer. Read more
source§

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

Flushes this entire writer’s output stream, ensuring all contents in intermediate buffers are fully written out.
source§

impl<RW> ByteWriter for ByteWriterWrapper<RW>where RW: BlockReader + BlockWriter,

source§

fn write_at(&mut self, buffer: &[u8], offset: usize) -> Result<usize, IoError>

Writes bytes of data from the given buffer to this writer. Read more
source§

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

Flushes this writer’s output stream, ensuring all contents in intermediate buffers are fully written out.
source§

impl<RW> From<RW> for ByteWriterWrapper<RW>where RW: BlockReader + BlockWriter,

source§

fn from(block_reader_writer: RW) -> Self

Converts to this type from the input type.
source§

impl<RW> KnownLength for ByteWriterWrapper<RW>where RW: KnownLength + BlockReader + BlockWriter,

source§

fn len(&self) -> usize

Returns the length (size in bytes) of this I/O stream or device.

Auto Trait Implementations§

§

impl<RW> RefUnwindSafe for ByteWriterWrapper<RW>where RW: RefUnwindSafe,

§

impl<RW> Send for ByteWriterWrapper<RW>where RW: Send,

§

impl<RW> Sync for ByteWriterWrapper<RW>where RW: Sync,

§

impl<RW> Unpin for ByteWriterWrapper<RW>where RW: Unpin,

§

impl<RW> UnwindSafe for ByteWriterWrapper<RW>where RW: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<!> for T

source§

fn from(t: !) -> T

Converts to this type from the input type.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere 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 Twhere 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 Twhere 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.