rust-analyzer/docs/user/features.md

165 lines
4.7 KiB
Markdown
Raw Normal View History

2019-03-20 10:05:03 +00:00
This documents is an index of features that rust-analyzer language server
provides. Shortcuts are for the default VS Code layout. If there's no shortcut,
you can use <kbd>Ctrl+Shift+P</kbd> to search for the corresponding action.
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
### Workspace Symbol <kbd>ctrl+t</kbd>
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
Uses fuzzy-search to find types, modules and function by name across your
2019-09-26 01:49:52 +00:00
project and dependencies. This is **the** most useful feature, which improves code
2019-03-20 10:05:03 +00:00
navigation tremendously. It mostly works on top of the built-in LSP
functionality, however `#` and `*` symbols can be used to narrow down the
search. Specifically,
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
- `Foo` searches for `Foo` type in the current workspace
- `foo#` searches for `foo` function in the current workspace
2019-03-29 13:51:20 +00:00
- `Foo*` searches for `Foo` type among dependencies, including `stdlib`
2019-03-20 10:05:03 +00:00
- `foo#*` searches for `foo` function among dependencies.
2019-03-20 09:17:12 +00:00
That is, `#` switches from "types" to all symbols, `*` switches from the current
workspace to dependencies.
2019-03-20 10:05:03 +00:00
### Document Symbol <kbd>ctrl+shift+o</kbd>
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
Provides a tree of the symbols defined in the file. Can be used to
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
* fuzzy search symbol in a file (super useful)
* draw breadcrumbs to describe the context around the cursor
* draw outline of the file
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
### On Typing Assists
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
Some features trigger on typing certain characters:
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
- typing `let =` tries to smartly add `;` if `=` is followed by an existing expression.
- Enter inside comments automatically inserts `///`
- typing `.` in a chain method call auto-indents
2019-03-20 09:17:12 +00:00
2019-04-21 09:52:54 +00:00
### Extend Selection
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
Extends the current selection to the encompassing syntactic construct
2019-04-21 09:52:54 +00:00
(expression, statement, item, module, etc). It works with multiple cursors. This
is a relatively new feature of LSP:
https://github.com/Microsoft/language-server-protocol/issues/613, check your
editor's LSP library to see if this feature is supported.
2019-04-23 20:32:30 +00:00
### Go to Definition
Navigates to the definition of an identifier.
### Go to Implementation
Navigates to the impl block of structs, enums or traits. Also implemented as a code lens.
### Go to Type Defintion
Navigates to the type of an identifier.
2019-04-21 09:52:54 +00:00
### Commands <kbd>ctrl+shift+p</kbd>
2019-03-20 09:17:12 +00:00
#### Run
Shows popup suggesting to run a test/benchmark/binary **at the current cursor
location**. Super useful for repeatedly running just a single test. Do bind this
to a shortcut!
2019-03-20 10:05:03 +00:00
#### Parent Module
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
Navigates to the parent module of the current module.
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
#### Matching Brace
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
If the cursor is on any brace (`<>(){}[]`) which is a part of a brace-pair,
moves cursor to the matching brace. It uses the actual parser to determine
braces, so it won't confuse generics with comparisons.
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
#### Join Lines
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
Join selected lines into one, smartly fixing up whitespace and trailing commas.
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
#### Show Syntax Tree
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
Shows the parse tree of the current file. It exists mostly for debugging
rust-analyzer itself.
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
#### Status
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
Shows internal statistic about memory usage of rust-analyzer
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
#### Run garbage collection
2019-03-20 09:17:12 +00:00
2019-03-20 10:05:03 +00:00
Manually triggers GC
2019-03-20 09:17:12 +00:00
2019-04-20 08:02:23 +00:00
#### Start Cargo Watch
Start `cargo watch` for live error highlighting. Will prompt to install if it's not already installed.
#### Stop Cargo Watch
Stop `cargo watch`
2019-10-25 11:16:46 +00:00
### Assists (Code Actions)
2019-03-20 10:05:03 +00:00
These are triggered in a particular context via light bulb. We use custom code on
the VS Code side to be able to position cursor. `<|>` signifies cursor
2019-03-20 09:17:12 +00:00
2019-10-25 11:16:46 +00:00
See [assists.md](./assists.md)
2019-03-20 10:05:03 +00:00
- Import path
```rust
// before:
impl std::fmt::Debug<|> for Foo {
}
// after:
2019-03-20 12:25:05 +00:00
use std::fmt::Debug;
2019-03-20 10:05:03 +00:00
impl Debug<|> for Foo {
}
```
2019-03-20 10:19:46 +00:00
### Magic Completions
In addition to usual reference completion, rust-analyzer provides some ✨magic✨
completions as well:
Keywords like `if`, `else` `while`, `loop` are completed with braces, and cursor
is placed at the appropriate position. Even though `if` is easy to type, you
still want to complete it, to get ` { }` for free! `return` is inserted with a
space or `;` depending on the return type of the function.
When completing a function call, `()` are automatically inserted. If function
takes arguments, cursor is positioned inside the parenthesis.
There are postifx completions, which can be triggerd by typing something like
`foo().if`. The word after `.` determines postifx completion, possible variants are:
- `expr.if` -> `if expr {}`
- `expr.match` -> `match expr {}`
- `expr.while` -> `while expr {}`
- `expr.ref` -> `&expr`
- `expr.refm` -> `&mut expr`
- `expr.not` -> `!expr`
- `expr.dbg` -> `dbg!(expr)`
There also snippet completions:
#### Inside Expressions
- `pd` -> `println!("{:?}")`
- `ppd` -> `println!("{:#?}")`
#### Inside Modules
- `tfn` -> `#[test] fn f(){}`
2019-05-27 09:26:15 +00:00
### Code highlighting
Experimental feature to let rust-analyzer highlight Rust code instead of using the
default highlighter.
#### Rainbow highlighting
Experimental feature that, given code highlighting using rust-analyzer is
active, will pick unique colors for identifiers.