tsdl

Crates.iotsdl
lib.rstsdl
version1.3.0
sourcesrc
created_at2024-09-01 15:30:00.718865
updated_at2024-11-21 15:32:13.572008
descriptionA downloader/builder of many tree-sitter parsers
homepage
repository
max_upload_size
id1359716
size183,692
Firas al-Khalil (stackmystack)

documentation

README

TSDL

CI badge crates.io badge

A downloader/builder of many tree-sitter parsers

Why?

To build parsers (.so/.dylib) and use them with your favourite bindings.

I created it more specifically for the ruby bindings.

Installation

You can either grab the binary for your platform from tsdl's releases or install via cargo:

cargo install tsdl

Usage

To build a parser:

tsdl build rust

To build many parsers:

tsdl build rust ruby json

If a configuration file (parsers.toml) is provided, then simply running:

tsdl build

will download all the pinned parsers.

Configuration

If no configuration is provided for the language you're asking for in parsers.toml, the latest parsers will be downloaded built.

If you wish to pin parser versions:

[parsers]
java = "v0.21.0"
json = "0.21.0" # The leading v is not necessary
python = "master"
typescript = { ref = "0.21.0", cmd = "make" }
cobol = { ref = "6a469068cacb5e3955bb16ad8dfff0dd792883c9", from = "https://github.com/yutaro-sakamoto/tree-sitter-cobol" }

Run:

tsdl config default

to get the default config used by tsdl in TOML.

[!IMPORTANT] All configuration you can pass to tsd build can be put in the parsers.toml, like tree-sitter-version, out-dir, etc.

build-dir = "/tmp/tsdl"
out-dir = "/usr/local/lib"

[parsers]
json = "0.21.0" # The leading v is not necessary
rust = "master"

[!IMPORTANT] All configuration specified in parsers.toml can be overridden with flags passed to tsdl, i.e.: tsdl build --build-dir "/tmp/tsdl" will override whatever value is the default of tsdl or in parsers.toml.

[!TIP] Check out Faveod/tree-sitter-parsers for an example configuration.

Commit count: 0

cargo fmt