mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 21:54:42 +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]
|
[alias]
|
||||||
|
# Automatically generates the ast and syntax kinds files
|
||||||
gen-kinds = "run --package tools -- gen-kinds"
|
gen-kinds = "run --package tools -- gen-kinds"
|
||||||
gen-tests = "run --package tools -- gen-tests"
|
gen-tests = "run --package tools -- gen-tests"
|
||||||
install-code = "run --package tools -- install-code"
|
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
|
* Porting libsyntax parser to rust-analyzer: currently rust-analyzer parses
|
||||||
only a tiny subset of Rust. This should be fixed by porting parsing
|
only a tiny subset of Rust. This should be fixed by porting parsing
|
||||||
functions from libsyntax one by one. Take a look at the
|
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
|
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".
|
for "how to port".
|
||||||
|
|
||||||
* Writing validators: by design, rust-analyzer is very lax about the
|
* 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.
|
Do take a look at the issue tracker.
|
||||||
|
|
||||||
If you don't know where to start, or have *any* questions or suggestions,
|
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 {
|
use {
|
||||||
ast,
|
ast,
|
||||||
SyntaxNodeRef, AstNode,
|
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 {
|
use {
|
||||||
ast,
|
ast,
|
||||||
SyntaxNodeRef, AstNode,
|
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(
|
Grammar(
|
||||||
single_byte_tokens: [
|
single_byte_tokens: [
|
||||||
[";", "SEMI"],
|
[";", "SEMI"],
|
||||||
|
@ -23,8 +25,9 @@ Grammar(
|
||||||
["^", "CARET"],
|
["^", "CARET"],
|
||||||
["%", "PERCENT"],
|
["%", "PERCENT"],
|
||||||
],
|
],
|
||||||
|
// TODO: Confirm surmision: the tokens which cannot be recorded in a single UTF-8 byte
|
||||||
multi_byte_tokens: [
|
multi_byte_tokens: [
|
||||||
[".", "DOT"],
|
[".", "DOT"], // Note: DOT is here because <TODO: REASON>
|
||||||
["..", "DOTDOT"],
|
["..", "DOTDOT"],
|
||||||
["...", "DOTDOTDOT"],
|
["...", "DOTDOTDOT"],
|
||||||
["..=", "DOTDOTEQ"],
|
["..=", "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)]
|
#![allow(bad_style, missing_docs, unreachable_pub)]
|
||||||
#![cfg_attr(rustfmt, rustfmt_skip)]
|
#![cfg_attr(rustfmt, rustfmt_skip)]
|
||||||
use super::SyntaxInfo;
|
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)]
|
#![allow(bad_style, missing_docs, unreachable_pub)]
|
||||||
#![cfg_attr(rustfmt, rustfmt_skip)]
|
#![cfg_attr(rustfmt, rustfmt_skip)]
|
||||||
use super::SyntaxInfo;
|
use super::SyntaxInfo;
|
||||||
|
|
Loading…
Reference in a new issue