Crates.io | tree-sitter-capnp |
lib.rs | tree-sitter-capnp |
version | 1.5.0 |
source | src |
created_at | 2023-01-22 23:40:59.80999 |
updated_at | 2023-07-15 05:51:32.461838 |
description | Cap'n Proto grammar for tree-sitter |
homepage | |
repository | https://github.com/amaanq/tree-sitter-capnp |
max_upload_size | |
id | 765427 |
size | 509,971 |
This crate provides a Cap'n Proto grammar for the tree-sitter parsing library.
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.20.3"
tree-sitter-capnp = "1.5.0"
Typically, you will use the language function to add this grammar to a tree-sitter Parser, and then use the parser to parse some code:
let code = r#"
@0xa73956d2621fc3ee;
using Cxx = import "/capnp/c++.capnp";
$Cxx.namespace("capnp::compiler");
struct Token {
union {
identifier @0 :Text;
stringLiteral @1 :Text;
binaryLiteral @9 :Data;
integerLiteral @2 :UInt64;
floatLiteral @3 :Float64;
operator @4 :Text;
parenthesizedList @5 :List(List(Token));
bracketedList @6 :List(List(Token));
}
startByte @7 :UInt32;
endByte @8 :UInt32;
}
struct Statement {
tokens @0 :List(Token);
union {
line @1 :Void;
block @2 :List(Statement);
}
docComment @3 :Text;
startByte @4 :UInt32;
endByte @5 :UInt32;
}
struct LexedTokens {
# Lexer output when asked to parse tokens that don't form statements.
tokens @0 :List(Token);
}
struct LexedStatements {
# Lexer output when asked to parse statements.
statements @0 :List(Statement);
}
"#;
let mut parser = Parser::new();
parser.set_language(tree_sitter_capnp::language()).expect("Error loading Cap'n Proto grammar");
let parsed = parser.parse(code, None);
If you have any questions, please reach out to us in the tree-sitter discussions page.