pub struct LineWriter<W> where
    W: Write,  { /* fields omitted */ }
Wraps a writer and buffers output to it, flushing whenever a newline
(0x0a, '\n') is detected.
The BufWriter struct wraps a writer and buffers its output.
But it only does this batched write when it goes out of scope, or when the
internal buffer is full. Sometimes, you'd prefer to write each line as it's
completed, rather than the entire buffer at once. Enter LineWriter. It
does exactly that.
Like [BufWriter], a LineWriter’s buffer will also be flushed when the
LineWriter goes out of scope or when its internal buffer is full.
If there's still a partial line in the buffer when the LineWriter is
dropped, it will flush those contents.
We can use LineWriter to write one line at a time, significantly
reducing the number of actual writes to the file.
use std::fs::{self, File};
use std::io::prelude::*;
use std::io::LineWriter;
fn main() -> std::io::Result<()> {
    let road_not_taken = b"I shall be telling this with a sigh
Somewhere ages and ages hence:
Two roads diverged in a wood, and I -
I took the one less traveled by,
And that has made all the difference.";
    let file = File::create("poem.txt")?;
    let mut file = LineWriter::new(file);
    file.write_all(b"I shall be telling this with a sigh")?;
    
    
    assert_eq!(fs::read_to_string("poem.txt")?, "");
    file.write_all(b"\n")?;
    assert_eq!(
        fs::read_to_string("poem.txt")?,
        "I shall be telling this with a sigh\n",
    );
    
    file.write_all(b"Somewhere ages and ages hence:
Two roads diverged in a wood, and I -
I took the one less traveled by,
And that has made all the difference.")?;
    
    
    
    file.flush()?;
    
    assert_eq!(fs::read("poem.txt")?, &road_not_taken[..]);
    Ok(())
}Creates a new LineWriter.
use std::fs::File;
use std::io::LineWriter;
fn main() -> std::io::Result<()> {
    let file = File::create("poem.txt")?;
    let file = LineWriter::new(file);
    Ok(())
}Creates a new LineWriter with a specified capacity for the internal
buffer.
use std::fs::File;
use std::io::LineWriter;
fn main() -> std::io::Result<()> {
    let file = File::create("poem.txt")?;
    let file = LineWriter::with_capacity(100, file);
    Ok(())
}Gets a reference to the underlying writer.
use std::fs::File;
use std::io::LineWriter;
fn main() -> std::io::Result<()> {
    let file = File::create("poem.txt")?;
    let file = LineWriter::new(file);
    let reference = file.get_ref();
    Ok(())
}Gets a mutable reference to the underlying writer.
Caution must be taken when calling methods on the mutable reference
returned as extra writes could corrupt the output stream.
use std::fs::File;
use std::io::LineWriter;
fn main() -> std::io::Result<()> {
    let file = File::create("poem.txt")?;
    let mut file = LineWriter::new(file);
    
    let reference = file.get_mut();
    Ok(())
}Unwraps this LineWriter, returning the underlying writer.
The internal buffer is written out before returning the writer.
An Err will be returned if an error occurs while flushing the buffer.
use std::fs::File;
use std::io::LineWriter;
fn main() -> std::io::Result<()> {
    let file = File::create("poem.txt")?;
    let writer: LineWriter<File> = LineWriter::new(file);
    let file: File = writer.into_inner()?;
    Ok(())
}
Write a buffer into this writer, returning how many bytes were written. Read more
Flush this output stream, ensuring that all intermediately buffered contents reach their destination. Read more
Attempts to write an entire buffer into this writer. Read more
Writes a formatted string into this writer, returning any error encountered. Read more
Creates a "by reference" adaptor for this instance of Write. Read more
Formats the value using the given formatter. Read more
type Error = !
🔬 This is a nightly-only experimental API. (try_from)
The type returned in the event of a conversion error.
🔬 This is a nightly-only experimental API. (try_from)
Immutably borrows from an owned value. Read more
🔬 This is a nightly-only experimental API. (get_type_id)
this method will likely be replaced by an associated static
type Error = <U as TryFrom<T>>::Error
🔬 This is a nightly-only experimental API. (try_from)
The type returned in the event of a conversion error.
🔬 This is a nightly-only experimental API. (try_from)
Mutably borrows from an owned value. Read more