#jinja #tree-sitter #parser #incremental-parser

tree-sitter-jinja2

jinja2 grammar for the tree-sitter parsing library

10 releases

0.0.12 Mar 15, 2025
0.0.11 Mar 15, 2025
0.0.10 Aug 29, 2024
0.0.8 Jun 26, 2024
0.0.5 Dec 28, 2023

#980 in Parser implementations

Download history 140/week @ 2025-01-08 147/week @ 2025-01-15 122/week @ 2025-01-22 166/week @ 2025-01-29 151/week @ 2025-02-05 173/week @ 2025-02-12 134/week @ 2025-02-19 174/week @ 2025-02-26 139/week @ 2025-03-05 676/week @ 2025-03-12 397/week @ 2025-03-19 331/week @ 2025-03-26 273/week @ 2025-04-02 265/week @ 2025-04-09 217/week @ 2025-04-16 177/week @ 2025-04-23

977 downloads per month
Used in 2 crates

MIT license

79KB
2.5K SLoC

C 2.5K SLoC Rust 31 SLoC // 0.5% comments JavaScript 28 SLoC // 0.3% comments Scheme 7 SLoC

tree-sitter-jinja2

Really basic parser for really basic highlighting.

npm install
tree-sitter generate && tree-sitter parse example-file.jinja2

lib.rs:

This crate provides Jinja2 language support for the tree-sitter parsing library.

Typically, you will use the language function to add this language to a tree-sitter Parser, and then use the parser to parse some code:

let code = r#"
"#;
let mut parser = tree_sitter::Parser::new();
let language = tree_sitter_jinja2::LANGUAGE;
parser
    .set_language(&language.into())
    .expect("Error loading Jinja2 parser");
let tree = parser.parse(code, None).unwrap();
assert!(!tree.root_node().has_error());

Dependencies

~4–280KB