Struct timeout_readwrite::reader::TimeoutReader
source · Expand description
The TimeoutReader struct adds read timeouts to any reader.
The read call on a Read instance will block forever until data is available.
A TimeoutReader will wait until data is available, up until an optional timeout,
before actually performing the read operation.
If any Read operation times out, the method called will return
an io::ErrorKind::TimedOut variant as the value of io::Error. All other
error values that would normally be produced by the underlying implementation
of the Read trait could also be produced by the TimeoutReader.
Implementations§
source§impl<H> TimeoutReader<H>where
H: Read + AsRawFd,
impl<H> TimeoutReader<H>where
H: Read + AsRawFd,
sourcepub fn new<T: Into<Option<Duration>>>(handle: H, timeout: T) -> TimeoutReader<H> ⓘ
pub fn new<T: Into<Option<Duration>>>(handle: H, timeout: T) -> TimeoutReader<H> ⓘ
Create a new TimeoutReader with an optional timeout.
Examples
This first example creates the TimeoutReader with a 5-second timeout.
use timeout_readwrite::TimeoutReader;
use std::fs::File;
use std::time::Duration;
let mut f = File::open("file.txt")?;
let mut rdr = TimeoutReader::new(f, Duration::new(5, 0));This example creates the TimeoutReader without a timeout at all.
use timeout_readwrite::TimeoutReader;
use std::fs::File;
use std::time::Duration;
let mut f = File::open("file.txt")?;
let mut rdr = TimeoutReader::new(f, None);Trait Implementations§
source§impl<H> Read for TimeoutReader<H>where
H: Read + AsRawFd,
impl<H> Read for TimeoutReader<H>where
H: Read + AsRawFd,
source§fn read(&mut self, buf: &mut [u8]) -> Result<usize>
fn read(&mut self, buf: &mut [u8]) -> Result<usize>
Pull some bytes from this source into the specified buffer, returning
how many bytes were read. Read more
1.36.0 · source§fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>
fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>
Like
read, except that it reads into a slice of buffers. Read moresource§fn is_read_vectored(&self) -> bool
fn is_read_vectored(&self) -> bool
🔬This is a nightly-only experimental API. (
can_vector)1.0.0 · source§fn read_to_end(&mut self, buf: &mut Vec<u8, Global>) -> Result<usize, Error>
fn read_to_end(&mut self, buf: &mut Vec<u8, Global>) -> Result<usize, Error>
Read all bytes until EOF in this source, placing them into
buf. Read more1.0.0 · source§fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
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 more1.6.0 · source§fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
Read the exact number of bytes required to fill
buf. Read moresource§fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
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>
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 more1.0.0 · source§fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
Creates a “by reference” adaptor for this instance of
Read. Read moresource§impl<H> Seek for TimeoutReader<H>where
H: Read + AsRawFd + Seek,
impl<H> Seek for TimeoutReader<H>where
H: Read + AsRawFd + Seek,
source§fn seek(&mut self, pos: SeekFrom) -> Result<u64>
fn seek(&mut self, pos: SeekFrom) -> Result<u64>
Seek to an offset, in bytes, in a stream. Read more
1.55.0 · source§fn rewind(&mut self) -> Result<(), Error>
fn rewind(&mut self) -> Result<(), Error>
Rewind to the beginning of a stream. Read more