Expand description
Syntax Tree library used throughout the rust-analyzer.
Properties:
- easy and fast incremental re-parsing
- graceful handling of errors
- full-fidelity representation (any text can be precisely represented as a syntax tree)
For more information, see the RFC. Current implementation is inspired by the Swift one.
The most interesting modules here are syntax_node
(which defines concrete
syntax tree) and ast
(which defines abstract syntax tree on top of the
CST). The actual parser live in a separate parser
crate, though the
lexer lives in this crate.
See api_walkthrough
test in this file for a quick API tour!
Re-exports§
pub use crate::ast::AstNode;
pub use crate::ast::AstToken;
pub use crate::ast::SourceFile;
Modules§
- Collection of assorted algorithms for syntax trees.
- Abstract Syntax Tree, layered on top of untyped
SyntaxNode
s - Things which exist to solve practical issues, but which shouldn’t exist.
- Syntax Tree editor
- Primitive tree editor, ed for trees.
- Utilities for validating string and char literals and turning them into values they represent.
- A set of utils methods to reuse on other abstraction levels
Macros§
- Formats arguments to a
SmolStr
, potentially without allocating. - Matches a
SyntaxNode
against anast
type.
Structs§
- Like
SyntaxNodePtr
, but remembers the type of node. - Internal node in the immutable tree. It has other nodes and tokens as children.
Parse
is the result of the parsing: a syntax tree and a collection of errors.- A
SmolStr
is a string type that has the following properties: - A builder that can be used to efficiently build a
SmolStr
. - Represents the result of unsuccessful tokenization, parsing or tree validation.
- A range in text, represented as a pair of
TextSize
. - A measure of text length. Also, equivalently, an index into text.
Enums§
- The kind of syntax node, e.g.
IDENT
,USE_KW
, orSTRUCT
. - There might be zero, one or two leaves at a given offset.
WalkEvent
describes tree walking process.
Traits§
- Convert value to
SmolStr
usingfmt::Display
, potentially without allocating.
Type Aliases§
- A “pointer” to a
SyntaxNode
, via location in the source code.