1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
//! Strongly-typed AST types for Rust, auto-generated from
//! [`tree-sitter-rust`](https://docs.rs/tree-sitter-rust)'s `node-types.json`.
//!
//! This crate is generated by [`treesitter-types`](https://docs.rs/treesitter-types) and is
//! automatically kept up to date when a new version of the grammar crate is released.
//!
//! These types have been tested by parsing the
//! [Rust compiler](https://github.com/rust-lang/rust) source code.
//!
//! See the [Tree-sitter](https://tree-sitter.github.io/tree-sitter/) project for more
//! information about the underlying parser framework.
//!
//! # Example
//!
//! ```
//! use treesitter_types_rust::*;
//!
//! // A minimal Rust hello-world program.
//! let src = b"\
//! fn main() {
//! println!(\"Hello, World!\");
//! }
//! ";
//!
//! // Parse the source with tree-sitter and convert into typed AST.
//! let mut parser = tree_sitter::Parser::new();
//! parser.set_language(&tree_sitter_rust::LANGUAGE.into()).unwrap();
//! let tree = parser.parse(src, None).unwrap();
//! let source_file = SourceFile::from_node(tree.root_node(), src).unwrap();
//!
//! // The source file has one top-level child: a function definition.
//! assert_eq!(source_file.children.len(), 1);
//!
//! // Unwrap the function item through the declaration statement wrapper.
//! let SourceFileChildren::DeclarationStatement(decl) = &source_file.children[0] else {
//! panic!("expected a declaration statement");
//! };
//! let DeclarationStatement::FunctionItem(func) = decl.as_ref() else {
//! panic!("expected a function item");
//! };
//!
//! // Check function metadata.
//! let FunctionItemName::Identifier(name) = &func.name else {
//! panic!("expected an identifier");
//! };
//! assert_eq!(name.text(), "main");
//! assert!(func.parameters.children.is_empty()); // no parameters
//! assert!(func.return_type.is_none()); // no return type
//!
//! // The body contains one statement: the `println!` macro invocation.
//! assert_eq!(func.body.children.len(), 1);
//! ```
pub use ;
pub use *;