mirror of
https://github.com/rust-lang/rust-analyzer
synced 2024-12-25 12:33:33 +00:00
Add cargo gen-kinds
documentation
This commit is contained in:
parent
81bf190f7a
commit
80eefcbc05
7 changed files with 43 additions and 4 deletions
|
@ -1,4 +1,5 @@
|
|||
[alias]
|
||||
# Automatically generates the ast and syntax kinds files
|
||||
gen-kinds = "run --package tools -- gen-kinds"
|
||||
gen-tests = "run --package tools -- gen-tests"
|
||||
install-code = "run --package tools -- install-code"
|
||||
|
|
|
@ -12,9 +12,9 @@ are some areas where contributions would be **especially** welcome:
|
|||
* Porting libsyntax parser to rust-analyzer: currently rust-analyzer parses
|
||||
only a tiny subset of Rust. This should be fixed by porting parsing
|
||||
functions from libsyntax one by one. Take a look at the
|
||||
[libsyntax parser](https://github.com/rust-lang/rust/blob/6b99adeb11313197f409b4f7c4083c2ceca8a4fe/src/libsyntax/parse/parser.rs)
|
||||
[libsyntax parser]
|
||||
for "what to port" and at the
|
||||
[Kotlin parser](https://github.com/JetBrains/kotlin/blob/4d951de616b20feca92f3e9cc9679b2de9e65195/compiler/frontend/src/org/jetbrains/kotlin/parsing/KotlinParsing.java)
|
||||
[Kotlin parser]
|
||||
for "how to port".
|
||||
|
||||
* Writing validators: by design, rust-analyzer is very lax about the
|
||||
|
@ -35,4 +35,23 @@ are some areas where contributions would be **especially** welcome:
|
|||
Do take a look at the issue tracker.
|
||||
|
||||
If you don't know where to start, or have *any* questions or suggestions,
|
||||
don't hesitate to chat at [Gitter](https://gitter.im/libsyntax2/Lobby)!
|
||||
don't hesitate to chat at [Gitter]!
|
||||
|
||||
# Code generation
|
||||
|
||||
Some of the components of this repository are generated through automatic processes. These are outlined below:
|
||||
|
||||
- `gen-kinds`: The kinds of tokens are reused in several places, so a generator is used.
|
||||
This process uses [tera] to generate, using data in [grammar.ron], the files:
|
||||
- [ast/generated.rs][ast generated] in `ra_syntax` based on [ast/generated.tera.rs][ast source]
|
||||
- [syntax_kinds/generated.rs][syntax_kinds generated] in `ra_syntax` based on [syntax_kinds/generated.tera.rs][syntax_kinds source]
|
||||
|
||||
[libsyntax parser]: https://github.com/rust-lang/rust/blob/6b99adeb11313197f409b4f7c4083c2ceca8a4fe/src/libsyntax/parse/parser.rs
|
||||
[Kotlin parser]: https://github.com/JetBrains/kotlin/blob/4d951de616b20feca92f3e9cc9679b2de9e65195/compiler/frontend/src/org/jetbrains/kotlin/parsing/KotlinParsing.java
|
||||
[Gitter]: https://gitter.im/libsyntax2/Lobby
|
||||
[tera]: https://tera.netlify.com/
|
||||
[grammar.ron]: ./crates/ra_syntax/src/grammar.ron
|
||||
[ast generated]: ./crates/ra_syntax/src/ast/generated.rs
|
||||
[ast source]: ./crates/ra_syntax/src/ast/generated.tera.rs
|
||||
[syntax_kinds generated]: ./crates/ra_syntax/src/syntax_kinds/generated.rs
|
||||
[syntax_kinds source]: ./crates/ra_syntax/src/syntax_kinds/generated.tera.rs
|
|
@ -1,3 +1,6 @@
|
|||
// This file is automatically generated based on the file `./generated.rs.tera` when `cargo gen-kinds` is run
|
||||
// Do not edit manually
|
||||
|
||||
use {
|
||||
ast,
|
||||
SyntaxNodeRef, AstNode,
|
||||
|
|
|
@ -1,3 +1,8 @@
|
|||
{# THIS File is not automatically generated:
|
||||
the below applies to the result of this template
|
||||
#}// This file is automatically generated based on the file `./generated.rs.tera` when `cargo gen-kinds` is run
|
||||
// Do not edit manually
|
||||
|
||||
use {
|
||||
ast,
|
||||
SyntaxNodeRef, AstNode,
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
// Stores definitions which must be used in multiple places
|
||||
// See `cargo gen-kinds` (defined in crates/tools/src/main.rs)
|
||||
Grammar(
|
||||
single_byte_tokens: [
|
||||
[";", "SEMI"],
|
||||
|
@ -23,8 +25,9 @@ Grammar(
|
|||
["^", "CARET"],
|
||||
["%", "PERCENT"],
|
||||
],
|
||||
// TODO: Confirm surmision: the tokens which cannot be recorded in a single UTF-8 byte
|
||||
multi_byte_tokens: [
|
||||
[".", "DOT"],
|
||||
[".", "DOT"], // Note: DOT is here because <TODO: REASON>
|
||||
["..", "DOTDOT"],
|
||||
["...", "DOTDOTDOT"],
|
||||
["..=", "DOTDOTEQ"],
|
||||
|
|
|
@ -1,3 +1,6 @@
|
|||
// This file is automatically generated based on the file `./generated.rs.tera` when `cargo gen-kinds` is run
|
||||
// Do not edit manually
|
||||
|
||||
#![allow(bad_style, missing_docs, unreachable_pub)]
|
||||
#![cfg_attr(rustfmt, rustfmt_skip)]
|
||||
use super::SyntaxInfo;
|
||||
|
|
|
@ -1,3 +1,8 @@
|
|||
{# THIS File is not automatically generated:
|
||||
the below applies to the result of this template
|
||||
#}// This file is automatically generated based on the file `./generated.rs.tera` when `cargo gen-kinds` is run
|
||||
// Do not edit manually
|
||||
|
||||
#![allow(bad_style, missing_docs, unreachable_pub)]
|
||||
#![cfg_attr(rustfmt, rustfmt_skip)]
|
||||
use super::SyntaxInfo;
|
||||
|
|
Loading…
Reference in a new issue