Struct tokio::io::Lines [−][src]
pub struct Lines<R> { /* fields omitted */ }Expand description
Read 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.
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::Pendingif 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.