Crates.io | tree-sitter-stack-graphs |
lib.rs | tree-sitter-stack-graphs |
version | |
source | src |
created_at | 2022-05-09 15:33:25.875382 |
updated_at | 2024-12-13 12:45:07.598247 |
description | Create stack graphs using tree-sitter parsers |
homepage | https://github.com/github/stack-graphs/tree/main/tree-sitter-stack-graphs |
repository | https://github.com/github/stack-graphs/ |
max_upload_size | |
id | 583312 |
Cargo.toml error: | TOML parse error at line 22, column 1 | 22 | autolib = false | ^^^^^^^ unknown field `autolib`, expected one of `name`, `version`, `edition`, `authors`, `description`, `readme`, `license`, `repository`, `homepage`, `documentation`, `build`, `resolver`, `links`, `default-run`, `default_dash_run`, `rust-version`, `rust_dash_version`, `rust_version`, `license-file`, `license_dash_file`, `license_file`, `licenseFile`, `license_capital_file`, `forced-target`, `forced_dash_target`, `autobins`, `autotests`, `autoexamples`, `autobenches`, `publish`, `metadata`, `keywords`, `categories`, `exclude`, `include` |
size | 0 |
The tree-sitter-stack-graphs
crate lets you create stack graphs using the tree-sitter grammar for a language.
To use this library, add the following to your Cargo.toml
:
[dependencies]
tree-sitter-stack-graphs = "0.10"
Check out our documentation for more details on how to use this library.
The command-line program for tree-sitter-stack-graphs
lets you do stack graph based analysis and lookup from the command line.
The CLI can be run as follows:
(Installed) Install the CLI using Cargo as follows:
cargo install --features cli tree-sitter-stack-graphs
After this, the CLI should be available as tree-sitter-stack-graphs
.
(From source) Instead of installing the CLI, it can also be run directly from the crate directory, as a replacement for a tree-sitter-stack-graphs
invocation, as follows:
cargo run --features cli --
The basic CLI workflow for the command-line program is to index source code and issue queries against the resulting database:
Index a source folder as follows:
tree-sitter-stack-graphs index SOURCE_DIR
Indexing will skip any files that have already be indexed. To force a re-index, add the -f
flag.
To check the status if a source folder, run:
tree-sitter-stack-graphs status SOURCE_DIR
To clean the database and start with a clean slate, run:
tree-sitter-stack-graphs clean
Pass the --delete
flag to not just empty the database, but also delete it. This is useful to resolve unsupported database version
errors that may occur after a version update.
Run a query to find the definition(s) for a reference on a given line and column, run:
tree-sitter-stack-graphs query definition SOURCE_PATH:LINE:COLUMN
Resulting definitions are printed, including a source line if the source file is available.
Discover all available commands and flags by passing the -h
flag to the CLI directly, or to any of the subcommands.
Starting a new project to develop stack graph definitions for your favourite language is as easy as running the init
command:
tree-sitter-stack-graphs init PROJECT_DIR
Answer the questions to provide information about the language, the grammar dependency, and the project and hit Generate
to generate the new project. Check out PROJECT_DIR/README.md
to find out how to start developing.
Check out examples of stack graph rules for typical language features.
The project is written in Rust, and requires a recent version installed. Rust can be installed and updated using rustup.
Build the project by running:
cargo build
Run the tests by running:
cargo test
The project consists of a library and a CLI.
By default, running cargo
only applies to the library.
To run cargo
commands on the CLI as well, add --features cli
or --all-features
.
Run the CLI from source as follows:
cargo run --features cli -- ARGS
Sources are formatted using the standard Rust formatted, which is applied by running:
cargo fmt
Licensed under either of
at your option.