5 releases (breaking)

0.5.0 Aug 25, 2024
0.4.0 Jul 20, 2024
0.3.0 Jul 9, 2024
0.2.0 Jul 6, 2024
0.1.0 Jul 4, 2024

#68 in Value formatting

Download history 355/week @ 2024-07-04 27/week @ 2024-07-11 120/week @ 2024-07-18 252/week @ 2024-07-25 356/week @ 2024-08-01 689/week @ 2024-08-08 439/week @ 2024-08-15 1024/week @ 2024-08-22 702/week @ 2024-08-29

2,964 downloads per month
Used in 3 crates (2 directly)

MIT license

140KB
4K SLoC

pretty_yaml is a semi-tolerant and configurable YAML formatter.

Basic Usage

You can format source code string by using format_text function.

use pretty_yaml::{config::FormatOptions, format_text};

let options = FormatOptions::default();
assert_eq!("- a\n- b\n", &format_text("-  a\n-     b", &options).unwrap());

For detailed documentation of configuration, please refer to Configuration.

If there're syntax errors in source code, it will return Err:

use pretty_yaml::{config::FormatOptions, format_text};

let options = FormatOptions::default();
assert!(format_text("{", &options).is_err());

Print Syntax Tree

If you have already parsed the syntax tree with yaml_parser, you can use print_tree to print it.

use pretty_yaml::{config::FormatOptions, print_tree};
use yaml_parser::{ast::{AstNode, Root}, parse};

let input = "-  a\n-     b";
let tree = parse(input).unwrap();
let root = Root::cast(tree).unwrap();

let options = FormatOptions::default();
assert_eq!("- a\n- b\n", &print_tree(&root, &options));

Dependencies

~2MB
~32K SLoC