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

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

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

Trait Implementations

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

Like read, except that it reads into a slice of buffers. Read more
🔬This is a nightly-only experimental API. (can_vector)
Determines if this Reader has an efficient read_vectored implementation. Read more
Read all bytes until EOF in this source, placing them into buf. Read more
Read all bytes until EOF in this source, appending them to buf. Read more
Read the exact number of bytes required to fill buf. Read more
🔬This is a nightly-only experimental API. (read_buf)
Pull some bytes from this source into the specified buffer. Read more
🔬This is a nightly-only experimental API. (read_buf)
Read the exact number of bytes required to fill cursor. Read more
Creates a “by reference” adaptor for this instance of Read. Read more
Transforms this Read instance to an Iterator over its bytes. Read more
Creates an adapter which will chain this stream with another. Read more
Creates an adapter which will read at most limit bytes from it. Read more

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.