#markup-language #jinja #html #svelte #astro #vue #github

markup_fmt

Configurable HTML/Vue/Svelte/Astro/Jinja/Twig/Nunjucks/Vento formatter

18 releases (7 breaking)

0.8.0 May 8, 2024
0.6.0 Mar 2, 2024
0.2.6 Dec 5, 2023
0.2.1 Nov 11, 2023

#78 in Template engine

Download history 49/week @ 2024-01-29 164/week @ 2024-02-12 369/week @ 2024-02-19 299/week @ 2024-02-26 74/week @ 2024-03-04 135/week @ 2024-03-11 181/week @ 2024-04-01 15/week @ 2024-04-08 12/week @ 2024-04-29 130/week @ 2024-05-06

142 downloads per month

MIT license

175KB
4.5K SLoC

markup_fmt is a configurable HTML/Vue/Svelte/Astro/Jinja/Twig/Nunjucks/Vento formatter.

Basic Usage

You can format source code string by using format_text function.

use markup_fmt::{config::FormatOptions, format_text, Language};

let options = FormatOptions::default();
assert_eq!("<div class=\"container\"></div>\n", &format_text(
    "<div class=container></div>",
    Language::Html,
    &options,
    |_, code, _| Ok::<_, ()>(code.into()),
).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 markup_fmt::{config::FormatOptions, format_text, FormatError, Language, SyntaxError};

let options = FormatOptions::default();
assert!(matches!(
    format_text(
        "<div>",
        Language::Html,
        &options,
        |_, code, _| Ok::<_, ()>(code.into()),
    ).unwrap_err(),
    FormatError::Syntax(SyntaxError { .. })
));

External formatter can return [Err] as well. This error will be aggregated and returned in FormatError::External:

use markup_fmt::{config::FormatOptions, format_text, FormatError, Language};

struct ExternalFormatterError;

let options = FormatOptions::default();
assert!(matches!(
    format_text(
        "<script>a</script>",
        Language::Html,
        &options,
        |_, _, _| Err(ExternalFormatterError),
    ).unwrap_err(),
    FormatError::External(ExternalFormatterError, _)
));

Dependencies

~2–3MB
~58K SLoC