Struct indent_write::fmt::IndentWriter [−][src]
pub struct IndentWriter<'i, W> { /* fields omitted */ }
Expand description
Adapter for writers to indent each line
An IndentWriter
adapts a fmt::Write
object to insert an indent before
each non-empty line. Specifically, this means it will insert an indent
between each newline when followed by a non-newline.
These writers can be nested to provide increasing levels of indentation.
Example
use indent_write::fmt::IndentWriter;
let output = String::new();
let mut indented = IndentWriter::new("\t", output);
// Lines will be indented
write!(indented, "Line 1\nLine 2\n");
// Empty lines will not be indented
write!(indented, "\n\nLine 3\n\n");
assert_eq!(indented.get_ref(), "\tLine 1\n\tLine 2\n\n\n\tLine 3\n\n");
Implementations
Create a new IndentWriter
.
Create a new IndentWriter
which will not add an indent to the first
written line.
Example
use indent_write::fmt::IndentWriter;
let mut buffer = String::new();
let mut writer = IndentWriter::new_skip_initial(" ", &mut buffer);
writeln!(writer, "Line 1").unwrap();
writeln!(writer, "Line 2").unwrap();
writeln!(writer, "Line 3").unwrap();
assert_eq!(buffer, "Line 1\n Line 2\n Line 3\n")
Extract the writer from the IndentWriter
, discarding any in-progress
indent state.
Trait Implementations
Writes a string slice into this writer, returning whether the write succeeded. Read more
Auto Trait Implementations
impl<'i, W> RefUnwindSafe for IndentWriter<'i, W> where
W: RefUnwindSafe,
impl<'i, W> Send for IndentWriter<'i, W> where
W: Send,
impl<'i, W> Sync for IndentWriter<'i, W> where
W: Sync,
impl<'i, W> Unpin for IndentWriter<'i, W> where
W: Unpin,
impl<'i, W> UnwindSafe for IndentWriter<'i, W> where
W: UnwindSafe,
Blanket Implementations
Mutably borrows from an owned value. Read more