pub struct Formatter<'a, W> { /* private fields */ }Expand description
A pretty printing HCL formatter.
§Examples
Format an HCL block as string:
use hcl::format::{Format, Formatter};
let mut buf = Vec::new();
let mut formatter = Formatter::new(&mut buf);
let block = hcl::Block::builder("user")
.add_label("johndoe")
.add_attribute(("age", 34))
.add_attribute(("email", "johndoe@example.com"))
.build();
block.format(&mut formatter)?;
let expected = r#"
user "johndoe" {
age = 34
email = "johndoe@example.com"
}
"#.trim_start();
let formatted = String::from_utf8(buf)?;
assert_eq!(formatted, expected);The builder() method can be used to construct a custom Formatter for
use with a Serializer:
use hcl::{format::Formatter, ser::Serializer};
let formatter = Formatter::builder()
.indent(b" ")
.dense(false)
.build(&mut writer);
let ser = Serializer::with_formatter(formatter);Implementations§
source§impl<'a> Formatter<'a, ()>
impl<'a> Formatter<'a, ()>
sourcepub fn builder() -> FormatterBuilder<'a>
pub fn builder() -> FormatterBuilder<'a>
Creates a new FormatterBuilder to start building a new Formatter.
Trait Implementations§
source§impl<'a> Default for Formatter<'a, Vec<u8>>
impl<'a> Default for Formatter<'a, Vec<u8>>
source§fn default() -> Self
fn default() -> Self
Creates the default Formatter which is specialized to use a pre-allocated Vec<u8> as
internal buffer.
The formatter can be passed to the format_string or
format_vec method of types implementing Format.
Alternatively, the internal buffer can be obtained by calling
into_inner after passing it to the format
method of a type implementing Format.
Auto Trait Implementations§
impl<'a, W> Freeze for Formatter<'a, W>where
W: Freeze,
impl<'a, W> RefUnwindSafe for Formatter<'a, W>where
W: RefUnwindSafe,
impl<'a, W> Send for Formatter<'a, W>where
W: Send,
impl<'a, W> Sync for Formatter<'a, W>where
W: Sync,
impl<'a, W> Unpin for Formatter<'a, W>where
W: Unpin,
impl<'a, W> UnwindSafe for Formatter<'a, W>where
W: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more