Struct iowrap::Eof

source ·
pub struct Eof<R: Read> { /* private fields */ }
Expand description

Track whether a stream has hit the end of file.

This allows slightly nicer code when reading lots of items using an uncooperative api, or when you want an UnexpectedEof only after the first byte. It also simplifies determining the last chunk when processing input in fixed-size chunks.

Eof::eof() and – for consistency – the Read implementation of Eof ignore ErrorKind::Interrupted errors and retry the operation.

§Example

use std::io;
use std::io::Read;
use std::fs::File;
use iowrap::Eof;

fn load() -> io::Result<Vec<u64>> {
  let mut ret = Vec::new();
  let mut file = Eof::new(File::open("foo.bin")?);
  while !file.eof()? {
    ret.push(third_party::parse_thing(&mut file));
  }
  Ok(ret)
}

mod third_party {
  use std::io::Read;
  pub fn parse_thing<R: Read>(mut from: R) -> u64 {
    let mut buf = [0u8; 8];
    from.read_exact(&mut buf).unwrap();
    u64::from(buf[0]) // oops!
  }
}

Implementations§

source§

impl<R: Read> Eof<R>

source

pub fn new(inner: R) -> Self

source

pub fn eof(&mut self) -> Result<bool>

Test if we are at the end of the stream. If false, then a proceeding read() will always succeed.

source

pub fn held_state(&self) -> Option<u8>

The buffered value, which we read while checking for EOF.

source

pub fn get_ref(&self) -> &R

source

pub fn get_mut(&mut self) -> &mut R

source

pub fn into_inner(self) -> R

Trait Implementations§

source§

impl<R: Read> Read for Eof<R>

source§

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

For consistency with eof(), this implementation retries the operation on ErrorKind::Interrupted errors.

1.36.0 · source§

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

Like read, except that it reads into a slice of buffers. Read more
source§

fn is_read_vectored(&self) -> bool

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

fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>

Read all bytes until EOF in this source, placing them into buf. Read more
1.0.0 · source§

fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>

Read all bytes until EOF in this source, appending them to buf. Read more
1.6.0 · source§

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

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

fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>

🔬This is a nightly-only experimental API. (read_buf)
Pull some bytes from this source into the specified buffer. Read more
source§

fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>

🔬This is a nightly-only experimental API. (read_buf)
Read the exact number of bytes required to fill cursor. Read more
1.0.0 · source§

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

Creates a “by reference” adaptor for this instance of Read. Read more
1.0.0 · source§

fn bytes(self) -> Bytes<Self>
where Self: Sized,

Transforms this Read instance to an Iterator over its bytes. Read more
1.0.0 · source§

fn chain<R>(self, next: R) -> Chain<Self, R>
where R: Read, Self: Sized,

Creates an adapter which will chain this stream with another. Read more
1.0.0 · source§

fn take(self, limit: u64) -> Take<Self>
where Self: Sized,

Creates an adapter which will read at most limit bytes from it. Read more

Auto Trait Implementations§

§

impl<R> Freeze for Eof<R>
where R: Freeze,

§

impl<R> RefUnwindSafe for Eof<R>
where R: RefUnwindSafe,

§

impl<R> Send for Eof<R>
where R: Send,

§

impl<R> Sync for Eof<R>
where R: Sync,

§

impl<R> Unpin for Eof<R>
where R: Unpin,

§

impl<R> UnwindSafe for Eof<R>
where R: 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> 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> ReadMany for T
where T: Read,

source§

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

Try quite hard to fill buf with bytes. Read more
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.