pub struct BufStream<T: BlockDevice<SIZE>, const SIZE: usize, const ALIGN: usize>
where Align<ALIGN>: Alignment,
{ /* private fields */ }
Expand description

A Stream wrapper for accessing a stream in block sized chunks.

BufStream<T, const SIZE: usize, const ALIGN: usize can be initialized with the following parameters.

  • T: The inner stream.
  • SIZE: The size of the block, this dictates the size of the internal buffer.
  • ALIGN: The alignment of the internal buffer.

If the buf provided to either Read::read or Write::write meets the following conditions the buf will be used directly instead of the intermediate buffer to avoid unnecessary copies:

  • buf.len() is a multiple of block size
  • buf has the same alignment as the internal buffer
  • The byte address of the inner device is aligned to a block size.

BufStream<T, const SIZE: usize, const ALIGN: usize implements the embedded_io_async traits, and implicitly handles the RMW (Read, Modify, Write) cycle for you.

Implementations§

source§

impl<T: BlockDevice<SIZE>, const SIZE: usize, const ALIGN: usize> BufStream<T, SIZE, ALIGN>
where Align<ALIGN>: Alignment,

source

pub fn new(inner: T) -> Self

Create a new BufStream around a hardware block device.

source

pub fn into_inner(self) -> T

Returns inner object.

Trait Implementations§

source§

impl<T: BlockDevice<SIZE>, const SIZE: usize, const ALIGN: usize> ErrorType for BufStream<T, SIZE, ALIGN>
where Align<ALIGN>: Alignment,

§

type Error = BufStreamError<<T as BlockDevice<SIZE>>::Error>

Error type of all the IO operations on this type.
source§

impl<T: BlockDevice<SIZE>, const SIZE: usize, const ALIGN: usize> Read for BufStream<T, SIZE, ALIGN>
where Align<ALIGN>: Alignment,

source§

async fn read(&mut self, buf: &mut [u8]) -> Result<usize, Self::Error>

Read some bytes from this source into the specified buffer, returning how many bytes were read. Read more
source§

async fn read_exact( &mut self, buf: &mut [u8] ) -> Result<(), ReadExactError<Self::Error>>

Read the exact number of bytes required to fill buf. Read more
source§

impl<T: BlockDevice<SIZE>, const SIZE: usize, const ALIGN: usize> Seek for BufStream<T, SIZE, ALIGN>
where Align<ALIGN>: Alignment,

source§

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

Seek to an offset, in bytes, in a stream.
source§

async fn rewind(&mut self) -> Result<(), Self::Error>

Rewind to the beginning of a stream.
source§

async fn stream_position(&mut self) -> Result<u64, Self::Error>

Returns the current seek position from the start of the stream.
source§

impl<T: BlockDevice<SIZE>, const SIZE: usize, const ALIGN: usize> Write for BufStream<T, SIZE, ALIGN>
where Align<ALIGN>: Alignment,

source§

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

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

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

Flush this output stream, ensuring that all intermediately buffered contents reach their destination.
source§

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

Write an entire buffer into this writer. Read more

Auto Trait Implementations§

§

impl<T, const SIZE: usize, const ALIGN: usize> !RefUnwindSafe for BufStream<T, SIZE, ALIGN>

§

impl<T, const SIZE: usize, const ALIGN: usize> Send for BufStream<T, SIZE, ALIGN>
where T: Send,

§

impl<T, const SIZE: usize, const ALIGN: usize> Sync for BufStream<T, SIZE, ALIGN>
where T: Sync,

§

impl<T, const SIZE: usize, const ALIGN: usize> Unpin for BufStream<T, SIZE, ALIGN>
where T: Unpin,

§

impl<T, const SIZE: usize, const ALIGN: usize> !UnwindSafe for BufStream<T, SIZE, ALIGN>

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

§

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.