pub struct Lines<R> { /* private fields */ }
io-util
only.Expand description
Reads lines from an AsyncBufRead
.
A Lines
can be turned into a Stream
with LinesStream
.
This type is usually created using the lines
method.
Implementations
Returns the next line in the stream.
Cancel safety
This method is cancellation safe.
Examples
use tokio::io::AsyncBufReadExt;
let mut lines = my_buf_read.lines();
while let Some(line) = lines.next_line().await? {
println!("length = {}", line.len())
}
Unwraps this Lines<R>
, returning the underlying reader.
Note that any leftover data in the internal buffer is lost. Therefore, a following read from the underlying reader may lead to data loss.
Polls for the next line in the stream.
This method returns:
Poll::Pending
if the next line is not yet available.Poll::Ready(Ok(Some(line)))
if the next line is available.Poll::Ready(Ok(None))
if there are no more lines in this stream.Poll::Ready(Err(err))
if an IO error occurred while reading the next line.
When the method returns Poll::Pending
, the Waker
in the provided
Context
is scheduled to receive a wakeup when more bytes become
available on the underlying IO resource. Note that on multiple calls to
poll_next_line
, only the Waker
from the Context
passed to the most
recent call is scheduled to receive a wakeup.