2018-09-16 06:29:34 -05:00
|
|
|
# Rust Analyzer
|
2018-01-10 12:58:38 -06:00
|
|
|
|
2018-09-16 06:29:34 -05:00
|
|
|
[![Build Status](https://travis-ci.org/matklad/rust-analyzer.svg?branch=master)](https://travis-ci.org/matklad/rust-analyzer)
|
|
|
|
[![Build status](https://ci.appveyor.com/api/projects/status/j56x1hbje8rdg6xk/branch/master?svg=true)](https://ci.appveyor.com/project/matklad/rust-analyzer/branch/master)
|
2018-01-27 18:15:30 -06:00
|
|
|
|
|
|
|
|
2018-09-16 06:29:34 -05:00
|
|
|
Rust Analyzer is an **experimental** modular compiler frontend for the
|
|
|
|
Rust language, which aims to lay a foundation for excellent IDE
|
|
|
|
support.
|
2018-01-10 13:49:22 -06:00
|
|
|
|
2018-09-16 06:29:34 -05:00
|
|
|
It doesn't implement much of compiler functionality yet, but the
|
|
|
|
white-space preserving Rust parser works, and there are significant
|
|
|
|
chunks of overall architecture (indexing, on-demand & lazy
|
|
|
|
computation, snapshotable world view) in place. Some basic IDE
|
|
|
|
functionality is provided via a language server.
|
2018-01-10 12:58:38 -06:00
|
|
|
|
2018-08-24 10:14:21 -05:00
|
|
|
## Quick Start
|
|
|
|
|
2018-09-16 07:36:09 -05:00
|
|
|
Rust analyzer builds on stable Rust >= 1.29.0.
|
|
|
|
|
2018-08-24 10:14:21 -05:00
|
|
|
```
|
2018-09-16 07:36:09 -05:00
|
|
|
# run tests
|
2018-08-24 10:14:21 -05:00
|
|
|
$ cargo test
|
|
|
|
|
2018-09-16 07:36:09 -05:00
|
|
|
# show syntax tree of a Rust file
|
|
|
|
$ cargo run --package ra_cli parse < crates/ra_syntax/src/lib.rs
|
2018-08-24 10:14:21 -05:00
|
|
|
|
2018-09-16 07:36:09 -05:00
|
|
|
# show symbols of a Rust file
|
|
|
|
$ cargo run --package ra_cli symbols < crates/ra_syntax/src/lib.rs
|
2018-08-24 10:14:21 -05:00
|
|
|
```
|
|
|
|
|
2018-09-16 07:36:09 -05:00
|
|
|
To try out the language server, see [these
|
|
|
|
instructions](./editors/README.md). Please note that the server is not
|
|
|
|
ready for general use yet. If you are looking for a Rust IDE that
|
|
|
|
works, use [IntelliJ
|
|
|
|
Rust](https://github.com/intellij-rust/intellij-rust) or
|
|
|
|
[RLS](https://github.com/rust-lang-nursery/rls). That being said, the
|
|
|
|
basic stuff works, and rust analyzer is developed in the rust analyzer
|
|
|
|
powered editor.
|
2018-09-08 11:23:52 -05:00
|
|
|
|
2018-08-24 10:14:21 -05:00
|
|
|
|
2018-09-16 06:29:34 -05:00
|
|
|
## Current Status and Plans
|
|
|
|
|
|
|
|
Rust analyzer aims to fill the same niche as the official [Rust
|
2018-09-21 06:16:48 -05:00
|
|
|
Language Server](https://github.com/rust-lang-nursery/rls), but uses a
|
|
|
|
significantly different architecture. More details can be found [in
|
|
|
|
this
|
|
|
|
thread](https://internals.rust-lang.org/t/2019-strategy-for-rustc-and-the-rls/8361),
|
|
|
|
but the core issue is that RLS works in the "wait until user stops
|
|
|
|
typing, run the build process, save the results of the analysis" mode,
|
|
|
|
which arguably is the wrong foundation for IDE.
|
2018-09-16 06:29:34 -05:00
|
|
|
|
|
|
|
Rust Analyzer is a hobby project at the moment, there's exactly zero
|
|
|
|
guarantees that it becomes production-ready one day.
|
|
|
|
|
|
|
|
The near/mid term plan is to work independently of the main rustc
|
|
|
|
compiler and implement at least simplistic versions of name
|
|
|
|
resolution, macro expansion and type inference. The purpose is two
|
|
|
|
fold:
|
|
|
|
|
|
|
|
* to quickly bootstrap usable and useful language server: solution
|
|
|
|
that covers 80% of Rust code will be useful for IDEs, and will be
|
|
|
|
vastly simpler than 100% solution.
|
|
|
|
|
|
|
|
* to understand how the consumer-side of compiler API should look like
|
|
|
|
(especially it's on-demand aspects). If you have
|
|
|
|
`get_expression_type` function, you can write a ton of purely-IDE
|
|
|
|
features on top of it, even if the function is only partially
|
|
|
|
correct. Plugin in the precise function afterwards should just make
|
|
|
|
IDE features more reliable.
|
|
|
|
|
|
|
|
The long term plan is to merge with the mainline rustc compiler,
|
|
|
|
probably around the HIR boundary? That is, use rust analyzer for
|
|
|
|
parsing, macro expansion and related bits of name resolution, but
|
|
|
|
leave the rest (including type inference and trait selection) to the
|
|
|
|
existing rustc.
|
2018-08-24 10:14:21 -05:00
|
|
|
|
|
|
|
## Code Walk-Through
|
|
|
|
|
2018-09-16 07:36:09 -05:00
|
|
|
### `crates/ra_syntax`
|
|
|
|
|
|
|
|
Rust syntax tree structure and parser. See
|
|
|
|
[RFC](https://github.com/rust-lang/rfcs/pull/2256) for some design
|
|
|
|
notes.
|
2018-08-24 10:14:21 -05:00
|
|
|
|
|
|
|
- `yellow`, red/green syntax tree, heavily inspired [by this](https://github.com/apple/swift/tree/ab68f0d4cbf99cdfa672f8ffe18e433fddc8b371/lib/Syntax)
|
|
|
|
- `grammar`, the actual parser
|
|
|
|
- `parser_api/parser_impl` bridges the tree-agnostic parser from `grammar` with `yellow` trees
|
|
|
|
- `grammar.ron` RON description of the grammar, which is used to
|
|
|
|
generate `syntax_kinds` and `ast` modules.
|
|
|
|
- `algo`: generic tree algorithms, including `walk` for O(1) stack
|
|
|
|
space tree traversal (this is cool) and `visit` for type-driven
|
|
|
|
visiting the nodes (this is double plus cool, if you understand how
|
2018-09-18 16:40:33 -05:00
|
|
|
`Visitor` works, you understand rust-analyzer).
|
2018-09-08 11:23:52 -05:00
|
|
|
|
2018-08-24 10:14:21 -05:00
|
|
|
|
2018-09-16 07:36:09 -05:00
|
|
|
### `crates/ra_editor`
|
|
|
|
|
|
|
|
All IDE features which can be implemented if you only have access to a
|
|
|
|
single file. `ra_editor` could be used to enhance editing of Rust code
|
|
|
|
without the need to fiddle with build-systems, file
|
|
|
|
synchronization and such.
|
|
|
|
|
|
|
|
In a sense, `ra_editor` is just a bunch of pure functions which take a
|
|
|
|
syntax tree as an input.
|
|
|
|
|
|
|
|
### `crates/salsa`
|
2018-08-24 10:14:21 -05:00
|
|
|
|
2018-09-16 07:36:09 -05:00
|
|
|
An implementation of red-green incremental compilation algorithm from
|
|
|
|
rust compiler. It makes all rust-analyzer features on-demand.
|
2018-08-24 10:14:21 -05:00
|
|
|
|
|
|
|
|
2018-09-16 07:36:09 -05:00
|
|
|
### `crates/ra_analysis`
|
2018-08-24 10:14:21 -05:00
|
|
|
|
|
|
|
A stateful library for analyzing many Rust files as they change.
|
2018-09-16 07:36:09 -05:00
|
|
|
`AnalysisHost` is a mutable entity (clojure's atom) which holds
|
|
|
|
current state, incorporates changes and handles out `Analysis` --- an
|
|
|
|
immutable consistent snapshot of world state at a point in time, which
|
|
|
|
actually powers analysis.
|
2018-08-24 10:14:21 -05:00
|
|
|
|
|
|
|
|
2018-09-16 07:36:09 -05:00
|
|
|
### `crates/ra_lsp_server`
|
2018-08-24 10:14:21 -05:00
|
|
|
|
2018-09-16 07:36:09 -05:00
|
|
|
An LSP implementation which uses `ra_analysis` for managing state and
|
|
|
|
`ra_editor` for actually doing useful stuff.
|
2018-08-24 10:14:21 -05:00
|
|
|
|
|
|
|
|
|
|
|
### `crates/cli`
|
|
|
|
|
|
|
|
A CLI interface to libsyntax
|
|
|
|
|
|
|
|
### `crate/tools`
|
|
|
|
|
2018-09-18 16:40:33 -05:00
|
|
|
Code-gen tasks, used to develop rust-analyzer:
|
2018-08-24 10:14:21 -05:00
|
|
|
|
|
|
|
- `cargo gen-kinds` -- generate `ast` and `syntax_kinds`
|
|
|
|
- `cargo gen-tests` -- collect inline tests from grammar
|
|
|
|
- `cargo install-code` -- build and install VS Code extension and server
|
|
|
|
|
2018-09-16 07:36:09 -05:00
|
|
|
### `editors/code`
|
2018-08-24 10:14:21 -05:00
|
|
|
|
|
|
|
VS Code plugin
|
2018-01-10 13:47:04 -06:00
|
|
|
|
|
|
|
|
2018-08-24 10:32:48 -05:00
|
|
|
## Performance
|
|
|
|
|
|
|
|
Non-incremental, but seems pretty fast:
|
|
|
|
|
|
|
|
```
|
2018-09-16 07:36:09 -05:00
|
|
|
$ cargo build --release --package ra_cli
|
2018-08-24 10:32:48 -05:00
|
|
|
$ wc -l ~/projects/rust/src/libsyntax/parse/parser.rs
|
|
|
|
7546 /home/matklad/projects/rust/src/libsyntax/parse/parser.rs
|
2018-09-16 07:36:09 -05:00
|
|
|
$ ./target/release/ra_cli parse < ~/projects/rust/src/libsyntax/parse/parser.rs --no-dump > /dev/null
|
2018-08-24 10:32:48 -05:00
|
|
|
parsing: 21.067065ms
|
|
|
|
```
|
|
|
|
|
2018-08-24 10:18:05 -05:00
|
|
|
## Getting in touch
|
|
|
|
|
|
|
|
@matklad can be found at Rust
|
|
|
|
[discord](https://discordapp.com/invite/rust-lang), in
|
|
|
|
#ides-and-editors.
|
|
|
|
|
|
|
|
|
2018-01-10 13:47:04 -06:00
|
|
|
## License
|
|
|
|
|
2018-09-16 07:36:09 -05:00
|
|
|
Rust analyzer is primarily distributed under the terms of both the MIT
|
|
|
|
license and the Apache License (Version 2.0).
|
2018-01-10 13:47:04 -06:00
|
|
|
|
|
|
|
See LICENSE-APACHE and LICENSE-MIT for details.
|