Crates.io | tree-sitter-ocaml |
lib.rs | tree-sitter-ocaml |
version | 0.23.1 |
source | src |
created_at | 2021-03-09 17:26:38.265805 |
updated_at | 2024-09-26 23:56:42.486195 |
description | OCaml grammar for tree-sitter |
homepage | |
repository | https://github.com/tree-sitter/tree-sitter-ocaml |
max_upload_size | |
id | 366424 |
size | 95,196,116 |
This crate provides OCaml language support for the tree-sitter parsing
library. There are separate languages for implementations (.ml
),
interfaces (.mli
) and types.
To use this crate, add it to the [dependencies]
section of your Cargo.toml
file. (Note that you will probably also need to depend on the
tree-sitter
crate to use the parsed result in any useful
way.)
[dependencies]
tree-sitter = "0.23"
tree-sitter-ocaml = "0.23"
Typically, you will use LANGUAGE_OCAML
to add this language
to a tree-sitter Parser
, and then use the parser to parse some code:
let code = r#"
module M = struct
let x = 0
end
"#;
let mut parser = tree_sitter::Parser::new();
let language = tree_sitter_ocaml::LANGUAGE_OCAML;
parser
.set_language(&language.into())
.expect("Error loading OCaml language");
let tree = parser.parse(code, None).unwrap();
Use LANGUAGE_OCAML_INTERFACE
to parse interface
files (with .mli
extension) and LANGUAGE_OCAML_TYPE
to parse type signatures.