mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-27 20:35:09 +00:00
document assists
This commit is contained in:
parent
ab9fef1ee2
commit
07a9e5c0e1
1 changed files with 212 additions and 57 deletions
|
@ -1,52 +1,30 @@
|
||||||
This documents is an index of features that rust-analyzer language server provides.
|
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.
|
||||||
|
|
||||||
### Go to symbol in workspace <kbd>ctrl+t</kbd>
|
### Workspace Symbol <kbd>ctrl+t</kbd>
|
||||||
|
|
||||||
It mostly works on top of the built-in LSP functionality, however `#` and `*`
|
Uses fuzzy-search to find types, modules and function by name across your
|
||||||
symbols can be used to narrow down the search. Specifically,
|
project and dependencies. This **the** most useful feature, which improves code
|
||||||
|
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,
|
||||||
|
|
||||||
- `#Foo` searches for `Foo` type in the current workspace
|
- `Foo` searches for `Foo` type in the current workspace
|
||||||
- `#foo#` searches for `foo` function in the current workspace
|
- `foo#` searches for `foo` function in the current workspace
|
||||||
- `#Foo*` searches for `Foo` type among dependencies, excluding `stdlib`
|
- `Foo*` searches for `Foo` type among dependencies, excluding `stdlib`
|
||||||
- `#foo#*` searches for `foo` function among dependencies.
|
- `foo#*` searches for `foo` function among dependencies.
|
||||||
|
|
||||||
That is, `#` switches from "types" to all symbols, `*` switches from the current
|
That is, `#` switches from "types" to all symbols, `*` switches from the current
|
||||||
workspace to dependencies.
|
workspace to dependencies.
|
||||||
|
|
||||||
### Commands <kbd>ctrl+shift+p</kbd>
|
### Document Symbol <kbd>ctrl+shift+o</kbd>
|
||||||
|
|
||||||
#### Show Rust Syntax Tree
|
Provides a tree of the symbols defined in the file. Can be used to
|
||||||
|
|
||||||
Shows the parse tree of the current file. It exists mostly for debugging
|
|
||||||
rust-analyzer itself.
|
|
||||||
|
|
||||||
#### Extend Selection
|
|
||||||
|
|
||||||
Extends the current selection to the encompassing syntactic construct
|
|
||||||
(expression, statement, item, module, etc). It works with multiple cursors. Do
|
|
||||||
bind this command to a key, its super-useful! Expected to be upstreamed to LSP soonish:
|
|
||||||
https://github.com/Microsoft/language-server-protocol/issues/613
|
|
||||||
|
|
||||||
#### Matching Brace
|
|
||||||
|
|
||||||
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.
|
|
||||||
|
|
||||||
#### Parent Module
|
|
||||||
|
|
||||||
Navigates to the parent module of the current module.
|
|
||||||
|
|
||||||
#### Join Lines
|
|
||||||
|
|
||||||
Join selected lines into one, smartly fixing up whitespace and trailing commas.
|
|
||||||
|
|
||||||
#### 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!
|
|
||||||
|
|
||||||
|
* fuzzy search symbol in a file (super useful)
|
||||||
|
* draw breadcrumbs to describe the context around the cursor
|
||||||
|
* draw outline of the file
|
||||||
|
|
||||||
### On Typing Assists
|
### On Typing Assists
|
||||||
|
|
||||||
|
@ -56,24 +34,52 @@ Some features trigger on typing certain characters:
|
||||||
- Enter inside comments automatically inserts `///`
|
- Enter inside comments automatically inserts `///`
|
||||||
- typing `.` in a chain method call auto-indents
|
- typing `.` in a chain method call auto-indents
|
||||||
|
|
||||||
|
### Commands <kbd>ctrl+shift+p</kbd>
|
||||||
|
|
||||||
|
#### Extend Selection
|
||||||
|
|
||||||
|
Extends the current selection to the encompassing syntactic construct
|
||||||
|
(expression, statement, item, module, etc). It works with multiple cursors. Do
|
||||||
|
bind this command to a key, it's super-useful! Expected to be upstreamed to LSP
|
||||||
|
soonish: https://github.com/Microsoft/language-server-protocol/issues/613
|
||||||
|
|
||||||
|
#### 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!
|
||||||
|
|
||||||
|
#### Parent Module
|
||||||
|
|
||||||
|
Navigates to the parent module of the current module.
|
||||||
|
|
||||||
|
#### Matching Brace
|
||||||
|
|
||||||
|
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.
|
||||||
|
|
||||||
|
#### Join Lines
|
||||||
|
|
||||||
|
Join selected lines into one, smartly fixing up whitespace and trailing commas.
|
||||||
|
|
||||||
|
#### Show Syntax Tree
|
||||||
|
|
||||||
|
Shows the parse tree of the current file. It exists mostly for debugging
|
||||||
|
rust-analyzer itself.
|
||||||
|
|
||||||
|
#### Status
|
||||||
|
|
||||||
|
Shows internal statistic about memory usage of rust-analyzer
|
||||||
|
|
||||||
|
#### Run garbage collection
|
||||||
|
|
||||||
|
Manually triggers GC
|
||||||
|
|
||||||
### Code Actions (Assists)
|
### Code Actions (Assists)
|
||||||
|
|
||||||
These are triggered in a particular context via light bulb. We use custom code on
|
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.
|
the VS Code side to be able to position cursor. `<|>` signifies cursor
|
||||||
|
|
||||||
|
|
||||||
- Flip `,`
|
|
||||||
|
|
||||||
```rust
|
|
||||||
// before:
|
|
||||||
fn foo(x: usize,<|> dim: (usize, usize))
|
|
||||||
// after:
|
|
||||||
fn foo(dim: (usize, usize), x: usize)
|
|
||||||
```
|
|
||||||
|
|
||||||
- Add `#[derive]`
|
- Add `#[derive]`
|
||||||
|
|
||||||
|
@ -106,14 +112,147 @@ impl<'a, T: Debug> Foo<'a, T> {
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
- Change visibility
|
- Add missing `impl` members
|
||||||
|
|
||||||
```rust
|
```rust
|
||||||
// before:
|
// before:
|
||||||
fn<|> foo() {}
|
trait Foo {
|
||||||
|
fn foo(&self);
|
||||||
|
fn bar(&self);
|
||||||
|
fn baz(&self);
|
||||||
|
}
|
||||||
|
|
||||||
// after
|
struct S;
|
||||||
pub(crate) fn foo() {}
|
|
||||||
|
impl Foo for S {
|
||||||
|
fn bar(&self) {}
|
||||||
|
<|>
|
||||||
|
}
|
||||||
|
|
||||||
|
// after:
|
||||||
|
trait Foo {
|
||||||
|
fn foo(&self);
|
||||||
|
fn bar(&self);
|
||||||
|
fn baz(&self);
|
||||||
|
}
|
||||||
|
|
||||||
|
struct S;
|
||||||
|
|
||||||
|
impl Foo for S {
|
||||||
|
fn bar(&self) {}
|
||||||
|
fn foo(&self) { unimplemented!() }
|
||||||
|
fn baz(&self) { unimplemented!() }<|>
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
- Import path
|
||||||
|
|
||||||
|
```rust
|
||||||
|
// before:
|
||||||
|
impl std::fmt::Debug<|> for Foo {
|
||||||
|
}
|
||||||
|
|
||||||
|
// after:
|
||||||
|
use std::fmt::Debug
|
||||||
|
|
||||||
|
impl Debug<|> for Foo {
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
- Change Visibility
|
||||||
|
|
||||||
|
```rust
|
||||||
|
// before:
|
||||||
|
<|>fn foo() {}
|
||||||
|
|
||||||
|
// after:
|
||||||
|
<|>pub(crate) fn foo() {}
|
||||||
|
|
||||||
|
// after:
|
||||||
|
<|>pub fn foo() {}
|
||||||
|
```
|
||||||
|
|
||||||
|
- Fill match arms
|
||||||
|
|
||||||
|
```rust
|
||||||
|
// before:
|
||||||
|
enum A {
|
||||||
|
As,
|
||||||
|
Bs,
|
||||||
|
Cs(String),
|
||||||
|
Ds(String, String),
|
||||||
|
Es{x: usize, y: usize}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let a = A::As;
|
||||||
|
match a<|> {}
|
||||||
|
}
|
||||||
|
|
||||||
|
// after:
|
||||||
|
enum A {
|
||||||
|
As,
|
||||||
|
Bs,
|
||||||
|
Cs(String),
|
||||||
|
Ds(String, String),
|
||||||
|
Es{x: usize, y: usize}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let a = A::As;
|
||||||
|
match <|>a {
|
||||||
|
A::As => (),
|
||||||
|
A::Bs => (),
|
||||||
|
A::Cs(_) => (),
|
||||||
|
A::Ds(_, _) => (),
|
||||||
|
A::Es{x, y} => (),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
-- Fill struct fields
|
||||||
|
|
||||||
|
```rust
|
||||||
|
// before:
|
||||||
|
struct S<'a, D> {
|
||||||
|
a: u32,
|
||||||
|
b: String,
|
||||||
|
c: (i32, i32),
|
||||||
|
d: D,
|
||||||
|
r: &'a str,
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let s = S<|> {}
|
||||||
|
}
|
||||||
|
|
||||||
|
// after:
|
||||||
|
struct S<'a, D> {
|
||||||
|
a: u32,
|
||||||
|
b: String,
|
||||||
|
c: (i32, i32),
|
||||||
|
d: D,
|
||||||
|
r: &'a str,
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let s = <|>S {
|
||||||
|
a: (),
|
||||||
|
b: (),
|
||||||
|
c: (),
|
||||||
|
d: (),
|
||||||
|
r: (),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
- Flip `,`
|
||||||
|
|
||||||
|
```rust
|
||||||
|
// before:
|
||||||
|
fn foo(x: usize,<|> dim: (usize, usize)) {}
|
||||||
|
// after:
|
||||||
|
fn foo(dim: (usize, usize), x: usize) {}
|
||||||
```
|
```
|
||||||
|
|
||||||
- Introduce variable:
|
- Introduce variable:
|
||||||
|
@ -131,6 +270,24 @@ fn foo() {
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
-- Remove `dbg!`
|
||||||
|
|
||||||
|
```rust
|
||||||
|
// before:
|
||||||
|
fn foo(n: usize) {
|
||||||
|
if let Some(_) = dbg!(n.<|>checked_sub(4)) {
|
||||||
|
// ...
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// after:
|
||||||
|
fn foo(n: usize) {
|
||||||
|
if let Some(_) = n.<|>checked_sub(4) {
|
||||||
|
// ...
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
- Replace if-let with match:
|
- Replace if-let with match:
|
||||||
|
|
||||||
```rust
|
```rust
|
||||||
|
@ -164,5 +321,3 @@ use algo:<|>:visitor::{Visitor, visit};
|
||||||
//after:
|
//after:
|
||||||
use algo::{<|>visitor::{Visitor, visit}};
|
use algo::{<|>visitor::{Visitor, visit}};
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue