#sass #formatter #css #less #formatting #configurable #smart

malva

Configurable, smart and fast CSS, SCSS, Sass and Less formatter

22 releases (11 breaking)

0.11.1 Dec 9, 2024
0.11.0 Oct 21, 2024
0.10.1 Aug 25, 2024
0.5.1 Jul 1, 2024
0.1.2 Nov 1, 2023

#216 in Web programming

Download history 820/week @ 2024-09-21 884/week @ 2024-09-28 1365/week @ 2024-10-05 1656/week @ 2024-10-12 1477/week @ 2024-10-19 1531/week @ 2024-10-26 1030/week @ 2024-11-02 948/week @ 2024-11-09 919/week @ 2024-11-16 970/week @ 2024-11-23 994/week @ 2024-11-30 1451/week @ 2024-12-07 1176/week @ 2024-12-14 801/week @ 2024-12-21 768/week @ 2024-12-28 888/week @ 2025-01-04

3,825 downloads per month
Used in 8 crates (5 directly)

MIT license

270KB
7K SLoC

Malva is a configurable, smart and fast CSS, SCSS, Sass and Less formatter.

Basic Usage

You can format source code string by using format_text function.

use malva::{config::FormatOptions, format_text, Syntax};

let options = FormatOptions::default();
assert_eq!("a {
  color: red;
}
", &format_text("a{color:red}", Syntax::Css, &options).unwrap());

For detailed documentation of configuration, please refer to Configuration on GitHub.

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

use malva::{config::FormatOptions, format_text, Syntax};

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

Print AST

If you have already parsed the AST with Raffia, you can use print_stylesheet to print it.

Please note that though you have AST, you still need to provide comments and specify syntax, also create LineBounds manually.

use malva::{config::FormatOptions, print_stylesheet, LineBounds, Syntax};
use raffia::{ast::Stylesheet, ParserBuilder};

let input = "a{color:red}";
let mut comments = vec![];
let mut parser = ParserBuilder::new(input)
    .syntax(Syntax::Css)
    .comments(&mut comments)
    .build();
let stylesheet = parser.parse::<Stylesheet>().unwrap();

let options = FormatOptions::default();
let line_bounds = LineBounds::new(input);
assert_eq!("a {
  color: red;
}
", &print_stylesheet(&stylesheet, &comments, Some(input), line_bounds, Syntax::Css, &options));

Dependencies

~2–2.8MB
~55K SLoC