nixpkgs/pkgs/development/tools/parsing/tree-sitter/grammars/README.md
2026-01-13 14:45:11 -05:00

126 lines
3.3 KiB
Markdown

# Tree-sitter Grammars
Use [grammar-sources.nix](grammar-sources.nix) to define tree-sitter grammar sources.
Tree-sitter grammars follow a common form for compatibility with the [`tree-sitter` CLI](https://tree-sitter.github.io/tree-sitter/cli/index.html).
This uniformity enables consistent packaging through shared tooling.
## Adding a Grammar
To declare a new package, map the language name to a set of metadata required for the build.
At a minimum, this must include the `version` and `src`.
You may use a shorthand [flakeref](https://nix.dev/manual/nix/2.24/command-ref/new-cli/nix3-flake#url-like-syntax) style `url` and `hash` for concise declarations.
If the hash is not yet known, use a [fake hash placeholder](https://nixos.org/manual/nixpkgs/stable/#sec-pkgs-fetchers-updating-source-hashes).
```nix
{
latex = {
version = "0.42.0";
url = "github:vandelay-industries/tree-sitter-latex";
hash = "";
};
}
```
This will expand to an element in `pkgs.tree-sitter.grammars` at build time:
```nix
{
tree-sitter-latex = {
language = "latex";
version = "0.42.0";
src = fetchFromGitHub {
owner = "vandelay-industries";
repo = "tree-sitter-latex";
ref = "v0.42.0";
hash = "";
};
};
}
```
Each entry is passed to [buildGrammar](../build-grammar.nix), which in turn populates `pkgs.tree-sitter-grammars`.
Attempt to build the new grammar: `nix-build -A tree-sitter-grammars.tree-sitter-latex`.
This will fail due to the invalid hash.
Review the downloaded source, then update the source definition with the printed source `hash`.
## Pinning Grammar Sources
To pin to a specific ref, append this to the source `url` to override the default version tag.
```nix
{
latex = {
version = "0.42.0";
url = "github:vandelay-industries/tree-sitter-latex/ccfd77db0ed799b6c22c214fe9d2937f47bc8b34";
hash = "";
};
}
```
This may be either a commit hash or tag.
## Supported sources
The `url` field supports the following prefixes:
- `github:` → uses `fetchFromGitHub`
- `gitlab:` → uses `fetchFromGitLab`
- `sourcehut:` → uses `fetchFromSourcehut`
To use [other fetchers](https://nixos.org/manual/nixpkgs/unstable/#chap-pkgs-fetchers), specify the `src` attribute directly:
```nix
{
foolang = {
version = "0.42.0";
src = fetchtorrent {
config = {
peer-limit-global = 100;
};
url = "magnet:?xt=urn:btih:dd8255ecdc7ca55fb0bbf81323d87062db1f6d1c";
hash = "";
};
};
}
```
## Modifying Build Behaviour
Additional attributes in the grammar definition are forwarded to `buildGrammar`, and then to `mkDerivation`.
This includes build-related flags and metadata.
```nix
{
foolang = {
version = "1729.0.0";
url = "sourcehut:~example/tree-sitter-foolang";
hash = "";
generate = true;
meta = {
license = lib.licenses.mit;
maintainers = with lib.maintainers; [
kimburgess
];
};
};
}
```
## Updating
All grammar sources have a default update script defined.
To manually trigger an update of a specific grammar definition:
```shell
nix-shell maintainers/scripts/update.nix --argstr package tree-sitter-grammars.tree-sitter-${name}
```
Or, to update all grammars:
```shell
nix-shell maintainers/scripts/update.nix --argstr path tree-sitter-grammars --argstr keep-going true
```