pub struct Reader<S> { /* private fields */ }
nonblocking
only.Expand description
Receives items from the queue.
Values sent by the writer will be added to the end of the reader’s buffer, and capacity can be sent back to the writer from the start of the reader’s buffer to allow it to write more data.
Implementations§
Source§impl<S> Reader<S>
impl<S> Reader<S>
Sourcepub fn is_writer_open(&self) -> bool
pub fn is_writer_open(&self) -> bool
Returns if the corresponding writer is still open.
If this is false
, unread data will still be available to read but a well-behaved writer
will not provide any new data.
Sourcepub fn has_data(&self) -> bool
pub fn has_data(&self) -> bool
Returns if data is available in the reader’s buffer.
If this is true it is guaranteed that the next call to buf
will return a non-empty
slice, unless consume
is called first.
Keep in mind that when using a reader and writer on separate threads, a reader that has no
data can receive data at any time - even between calls to has_data
and other functions.
Sourcepub fn is_full(&self) -> bool
pub fn is_full(&self) -> bool
Returns if the buffer is full, i.e all space is allocated to the reader and any write operations will fail.
If this is true a reader can only resume the writer by calling consume
to pass capacity
to the writer.
Keep in mind that when using a reader and writer on separate threads, a reader that is not
full can become full at any time - even between calls to is_full
and other functions.
Sourcepub fn buf<T>(&self) -> Region<'_, T>where
S: Storage<T>,
pub fn buf<T>(&self) -> Region<'_, T>where
S: Storage<T>,
Gets the readable buffer.
This function is a lower-level call. It needs to be paired with the consume
method to
function properly. When calling this method, none of the contents will be “read” in the
sense that later calling buf
may return the same contents. As such, consume
must
be called with the number of bytes that are consumed from this buffer to ensure that the
items are never returned twice.
An empty buffer returned indicates that no data is available to read.
§Panics
This function may panic if the underlying storage panics when trying to get a slice to the data. This may happen if queue was created with a ring that has a larger capacity than the storage.
Sourcepub fn consume(&mut self, amt: usize)
pub fn consume(&mut self, amt: usize)
Marks items at the start of the reader buffer as consumed, removing them from the slice
returned by buf
and adding their capacity to the end of the writer’s buffer. Since
queues have a fixed underlying length, calling this is required to allow the transfer of
more data.
§Panics
This function will panic if amt
is larger than the reader’s available data buffer.
Sourcepub fn read<T>(&mut self, buf: &mut [T]) -> usize
pub fn read<T>(&mut self, buf: &mut [T]) -> usize
Pulls some items from this queue into the specified buffer, returning how many items were read.
§Return
It is guaranteed that the return value is <= buf.len()
.
A return value of 0
indicates one of these three scenarios:
- No data was available to read.
- The writer has closed and all items have been read.
- The buffer specified had a length of 0.
Trait Implementations§
Source§impl<S> BufRead for Reader<S>
Available on crate feature std-io
only.
impl<S> BufRead for Reader<S>
std-io
only.Source§fn fill_buf(&mut self) -> Result<&[u8]>
fn fill_buf(&mut self) -> Result<&[u8]>
Read
methods, if empty. Read moreSource§fn consume(&mut self, amt: usize)
fn consume(&mut self, amt: usize)
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 has_data_left(&mut self) -> Result<bool, Error>
fn has_data_left(&mut self) -> Result<bool, Error>
buf_read_has_data_left
)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>
byte
or EOF is reached. Read more1.0.0 · Source§fn read_line(&mut self, buf: &mut String) -> Result<usize, Error>
fn read_line(&mut self, buf: &mut String) -> Result<usize, Error>
0xA
byte) is reached, and append
them to the provided String
buffer. Read moreSource§impl<S> Read for Reader<S>
Available on crate feature std-io
only.
impl<S> Read for Reader<S>
std-io
only.Source§fn read(&mut self, buf: &mut [u8]) -> Result<usize>
fn read(&mut self, buf: &mut [u8]) -> Result<usize>
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>
read
, except that it reads into a slice of buffers. Read moreSource§fn is_read_vectored(&self) -> bool
fn is_read_vectored(&self) -> bool
can_vector
)1.0.0 · Source§fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
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>
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>
buf
. Read moreSource§fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
read_buf
)Source§fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>
fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>
read_buf
)cursor
. Read more1.0.0 · Source§fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
Read
. Read more