pub struct Retry<I> { /* private fields */ }
Expand description
An adapter that retries reading/writing operations of the underlying reader or writer.
This struct is generally created by calling retry()
on a reader or writer.
Please see the documentation of Stream::retry
for more details.
Implementations§
Trait Implementations§
Source§impl<R: BufRead + BufRead> BufRead for Retry<R>
impl<R: BufRead + BufRead> BufRead for Retry<R>
Source§fn fill_buf(&mut self) -> Result<&[u8]>
fn fill_buf(&mut self) -> Result<&[u8]>
Returns the contents of the internal buffer, filling it with more data, via
Read
methods, if empty. Read moreSource§fn consume(&mut self, amt: usize)
fn consume(&mut self, amt: usize)
Marks the given
amount
of additional bytes from the internal buffer as having been read.
Subsequent calls to read
only return bytes that have not been marked as read. Read moreSource§fn read_line(&mut self, buf: &mut String) -> Result<usize>
fn read_line(&mut self, buf: &mut String) -> Result<usize>
Reads all bytes until a newline (the
0xA
byte) is reached, and append
them to the provided String
buffer. Read moreSource§fn has_data_left(&mut self) -> Result<bool, Error>
fn has_data_left(&mut self) -> Result<bool, Error>
🔬This is a nightly-only experimental API. (
buf_read_has_data_left
)Checks if there is any data left to be
read
. Read more1.83.0 · Source§fn skip_until(&mut self, byte: u8) -> Result<usize, Error>
fn skip_until(&mut self, byte: u8) -> Result<usize, Error>
Skips all bytes until the delimiter
byte
or EOF is reached. Read moreSource§impl<R: BufRead> BufRead for Retry<R>
impl<R: BufRead> BufRead for Retry<R>
Source§fn fill_buf(&mut self) -> Result<&[u8]>
fn fill_buf(&mut self) -> Result<&[u8]>
Fills the internal buffer of this object, returning the buffer contents. Read more
Source§fn consume(&mut self, amt: usize)
fn consume(&mut self, amt: usize)
Tells this buffer that
amt
bytes have been consumed from the buffer,
so they should no longer be returned in calls to read
. Read moreSource§fn read_to_end<B>(&mut self, buf: &mut B) -> Result<()>
fn read_to_end<B>(&mut self, buf: &mut B) -> Result<()>
Read all bytes until EOF in this source, placing them into
buf
. Read moreSource§fn read_exact(&mut self, buf: &mut Cursor<&mut [u8]>) -> Result<()>
fn read_exact(&mut self, buf: &mut Cursor<&mut [u8]>) -> Result<()>
Read the exact number of bytes required to fill
buf
. Read moreSource§fn bytes(self) -> Bytes<Self> ⓘwhere
Self: Sized,
fn bytes(self) -> Bytes<Self> ⓘwhere
Self: Sized,
Transforms this buffered reader into an iterator over its bytes. Read more
Source§fn read_until<W>(&mut self, delim: u8, buf: &mut W) -> Result<()>
fn read_until<W>(&mut self, delim: u8, buf: &mut W) -> Result<()>
Read all bytes into a buffer until a delimiter is reached. Read more
Source§impl<R: BufReadGrow> BufReadGrow for Retry<R>
impl<R: BufReadGrow> BufReadGrow for Retry<R>
Source§fn grow_buf(&mut self) -> Result<&[u8]>
fn grow_buf(&mut self) -> Result<&[u8]>
Grows the internal buffer of this object by at least one byte,
returning the buffer contents. Read more
Source§fn fill_buf_min(&mut self, size: usize) -> Result<&[u8]>
fn fill_buf_min(&mut self, size: usize) -> Result<&[u8]>
Fills the internal buffer to at least the specified amount,
returning the buffer contents. Read more
Source§fn read_until2(&mut self, delims: (u8, u8), buf: &mut Vec<u8>) -> Result<()>
fn read_until2(&mut self, delims: (u8, u8), buf: &mut Vec<u8>) -> Result<()>
Read all bytes into a buffer until two consecutive delimiters are reached. Read more
Source§fn skip_until2(&mut self, delims: (u8, u8)) -> Result<()>
fn skip_until2(&mut self, delims: (u8, u8)) -> Result<()>
Skip all bytes until two consecutive delimiters are reached. Read more
fn decode_utf8(self) -> Utf8Reader<Self>where
Self: Sized,
Source§impl<I: Read> Read for Retry<I>
impl<I: Read> Read for Retry<I>
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
Source§fn chain<R>(self, next: R) -> Chain<Self, R> ⓘ
fn chain<R>(self, next: R) -> Chain<Self, R> ⓘ
Creates an adaptor which will chain this stream with another. Read more
Source§impl<R: Read + Read> Read for Retry<R>
impl<R: Read + Read> Read for Retry<R>
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
Source§fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize>
fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize>
Reads all bytes until EOF in this source, placing them into
buf
. Read moreSource§fn read_to_string(&mut self, buf: &mut String) -> Result<usize>
fn read_to_string(&mut self, buf: &mut String) -> Result<usize>
Reads all bytes until EOF in this source, appending them to
buf
. Read moreSource§fn read_exact(&mut self, buf: &mut [u8]) -> Result<()>
fn read_exact(&mut self, buf: &mut [u8]) -> Result<()>
Reads the exact number of bytes required to fill
buf
. Read more1.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
)Source§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
)Reads 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<I: Write + Write> Write for Retry<I>
impl<I: Write + Write> Write for Retry<I>
Source§fn write(&mut self, buf: &[u8]) -> Result<usize>
fn write(&mut self, buf: &[u8]) -> Result<usize>
Writes a buffer into this writer, returning how many bytes were written. Read more
Source§fn flush(&mut self) -> Result<()>
fn flush(&mut self) -> Result<()>
Flushes this output stream, ensuring that all intermediately buffered
contents reach their destination. Read more
Source§fn write_all(&mut self, buf: &[u8]) -> Result<()>
fn write_all(&mut self, buf: &[u8]) -> Result<()>
Attempts to write an entire buffer into this writer. Read more
Source§fn write_fmt(&mut self, fmt: Arguments<'_>) -> Result<()>
fn write_fmt(&mut self, fmt: Arguments<'_>) -> Result<()>
Writes a formatted string into this writer, returning any error
encountered. Read more
Source§fn is_write_vectored(&self) -> bool
fn is_write_vectored(&self) -> bool
🔬This is a nightly-only experimental API. (
can_vector
)Source§impl<I: Write> Write for Retry<I>
impl<I: Write> Write for Retry<I>
Auto Trait Implementations§
impl<I> Freeze for Retry<I>where
I: Freeze,
impl<I> RefUnwindSafe for Retry<I>where
I: RefUnwindSafe,
impl<I> Send for Retry<I>where
I: Send,
impl<I> Sync for Retry<I>where
I: Sync,
impl<I> Unpin for Retry<I>where
I: Unpin,
impl<I> UnwindSafe for Retry<I>where
I: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<R> Stream for Rwhere
R: ?Sized,
impl<R> Stream for Rwhere
R: ?Sized,
Source§impl<R> TrustRead for Rwhere
R: Read,
impl<R> TrustRead for Rwhere
R: Read,
Source§fn is_trusted(&self) -> bool
fn is_trusted(&self) -> bool
Default impl which always returns false
.
Enable the nightly
feature to specialize this impl for various types.