arborium-clojure
Clojure grammar for tree-sitter.
Functional Lisp dialect for the JVM with strong concurrency support; official site: clojure.org.
| Inventor | Rich Hickey |
| Year | 2007 |
Usage
use language;
use Parser;
let mut parser = new;
parser.set_language.expect;
let source_code = "/* your clojure code here */";
let tree = parser.parse.unwrap;
println!;
For most use cases, prefer the main arborium crate:
[]
= { = "*", = ["clojure"] }
Or use this crate directly:
[]
= "*"
About Arborium
This crate is part of Arborium, a collection of tree-sitter grammars packaged as Rust crates, maintained by Amos Wenger.
This crate packages a parser.c file generated by the tree-sitter CLI. It exports a language() function returning the tree-sitter Language for clojure.
Why separate crates? Tree-sitter parsers can be large (some exceed 1MB of generated C). Splitting languages into separate crates means you only compile what you need, and parallel/incremental builds are more effective.
Build Requirements
- Rust: MSRV is 1.85.0 (Rust 2024 edition)
- C compiler: This crate compiles C code via the
cccrate
Supported Targets
- All major platforms: Linux, macOS, Windows
- WebAssembly:
wasm32-unknown-unknown(with custom sysroot)
Upstream Grammar
| Repository | sogaiu/tree-sitter-clojure |
| Commit | e43eff80d17cf34852dcd92ca5e6986d23a7040f |
| License | Unlicense |
To regenerate after upstream updates:
Found a grammar bug? Please report it to the upstream repository.
Safety
This crate uses unsafe for FFI bindings to the tree-sitter C library. The unsafe surface is minimal and limited to what tree-sitter requires. The generated parser code is produced by tree-sitter's own code generator.
Versioning
Crate versions track Arborium releases, not upstream grammar versions. The upstream commit is recorded above. A major version bump occurs when grammar changes affect node names or structure (breaking for query consumers).
License
- Generated parser code (
parser.c): Unlicense (from upstream grammar) - Arborium glue code: MIT OR Apache-2.0
Contributing
- Issues: github.com/bearcove/arborium/issues
- Repository: github.com/bearcove/arborium