21 releases (7 breaking)

0.24.4 Nov 10, 2024
0.23.2 Oct 1, 2024
0.22.6 May 5, 2024
0.22.2 Mar 17, 2024
0.2.0 May 12, 2020

#2113 in Parser implementations

Download history 4976/week @ 2024-08-04 5749/week @ 2024-08-11 6843/week @ 2024-08-18 4885/week @ 2024-08-25 4598/week @ 2024-09-01 4035/week @ 2024-09-08 4978/week @ 2024-09-15 4887/week @ 2024-09-22 5238/week @ 2024-09-29 5375/week @ 2024-10-06 4471/week @ 2024-10-13 4685/week @ 2024-10-20 4069/week @ 2024-10-27 5051/week @ 2024-11-03 4775/week @ 2024-11-10 4083/week @ 2024-11-17

18,183 downloads per month
Used in 13 crates (2 directly)

MIT license

655KB
16K SLoC

C 12K SLoC // 0.1% comments Rust 4.5K SLoC // 0.0% comments

Tree-sitter Tags

crates.io badge

Usage

Add this crate, and the language-specific crates for whichever languages you want to parse, to your Cargo.toml:

[dependencies]
tree-sitter-tags = "0.19"
tree-sitter-javascript = "0.19"
tree-sitter-python = "0.19"

Create a tag context. You need one of these for each thread that you're using for tag computation:

use tree_sitter_tags::TagsContext;

let context = TagsContext::new();

Load some tagging queries from the queries directory of some language repositories:

use tree_sitter_tags::TagsConfiguration;

let python_config = TagsConfiguration::new(
    tree_sitter_python::language(),
    tree_sitter_python::TAGGING_QUERY,
    "",
).unwrap();

let javascript_config = TagsConfiguration::new(
    tree_sitter_javascript::language(),
    tree_sitter_javascript::TAGGING_QUERY,
    tree_sitter_javascript::LOCALS_QUERY,
).unwrap();

Compute code navigation tags for some source code:

let tags = context.generate_tags(
    &javascript_config,
    b"class A { getB() { return c(); } }",
    None,
);

for tag in tags {
    println!("kind: {:?}", tag.kind);
    println!("range: {:?}", tag.range);
    println!("name_range: {:?}", tag.name_range);
    println!("docs: {:?}", tag.docs);
}

Dependencies

~2.5–4.5MB
~83K SLoC