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

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

#959 in Parser implementations

Download history 151/week @ 2025-01-03 149/week @ 2025-01-10 151/week @ 2025-01-17 121/week @ 2025-01-24 165/week @ 2025-01-31 149/week @ 2025-02-07 164/week @ 2025-02-14 147/week @ 2025-02-21 166/week @ 2025-02-28 134/week @ 2025-03-07 778/week @ 2025-03-14 373/week @ 2025-03-21 319/week @ 2025-03-28 240/week @ 2025-04-04 264/week @ 2025-04-11 188/week @ 2025-04-18

1,081 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