rust/docs/user/assists.md

268 lines
3.2 KiB
Markdown
Raw Normal View History

2019-10-25 14:16:46 +03:00
# Assists
2019-10-26 21:17:39 +03:00
Cursor position or selection is signified by `┃` character.
2019-10-25 23:38:15 +03:00
## `add_derive`
Adds a new `#[derive()]` clause to a struct or enum.
```rust
// BEFORE
struct Point {
x: u32,
2019-10-26 21:17:39 +03:00
y: u32,┃
2019-10-25 23:38:15 +03:00
}
// AFTER
#[derive()]
struct Point {
x: u32,
y: u32,
}
```
## `add_explicit_type`
2019-10-26 19:08:13 +03:00
Specify type for a let binding.
2019-10-25 23:38:15 +03:00
```rust
// BEFORE
fn main() {
2019-10-26 21:17:39 +03:00
let x┃ = 92;
2019-10-25 23:38:15 +03:00
}
// AFTER
fn main() {
let x: i32 = 92;
}
```
## `add_impl`
2019-10-26 19:08:13 +03:00
Adds a new inherent impl for a type.
2019-10-25 23:38:15 +03:00
```rust
// BEFORE
struct Ctx<T: Clone> {
2019-10-26 21:17:39 +03:00
data: T,┃
2019-10-25 23:38:15 +03:00
}
// AFTER
struct Ctx<T: Clone> {
data: T,
}
impl<T: Clone> Ctx<T> {
}
```
## `add_impl_default_members`
2019-10-26 19:08:13 +03:00
Adds scaffold for overriding default impl members.
2019-10-25 23:38:15 +03:00
```rust
// BEFORE
trait T {
Type X;
fn foo(&self);
fn bar(&self) {}
}
impl T for () {
Type X = ();
2019-10-26 21:17:39 +03:00
fn foo(&self) {}┃
2019-10-25 23:38:15 +03:00
}
// AFTER
trait T {
Type X;
fn foo(&self);
fn bar(&self) {}
}
impl T for () {
Type X = ();
fn foo(&self) {}
fn bar(&self) {}
}
```
## `add_impl_missing_members`
2019-10-26 19:08:13 +03:00
Adds scaffold for required impl members.
2019-10-25 23:38:15 +03:00
```rust
// BEFORE
trait T {
Type X;
fn foo(&self);
fn bar(&self) {}
}
2019-10-26 21:17:39 +03:00
impl T for () {┃
2019-10-25 23:38:15 +03:00
}
// AFTER
trait T {
Type X;
fn foo(&self);
fn bar(&self) {}
}
impl T for () {
fn foo(&self) { unimplemented!() }
}
```
## `apply_demorgan`
Apply [De Morgan's law](https://en.wikipedia.org/wiki/De_Morgan%27s_laws).
This transforms expressions of the form `!l || !r` into `!(l && r)`.
This also works with `&&`. This assist can only be applied with the cursor
on either `||` or `&&`, with both operands being a negation of some kind.
This means something of the form `!x` or `x != y`.
```rust
// BEFORE
fn main() {
2019-10-26 21:17:39 +03:00
if x != 4 ||┃ !y {}
2019-10-25 23:38:15 +03:00
}
// AFTER
fn main() {
if !(x == 4 && y) {}
}
```
2019-10-26 17:37:04 +03:00
## `change_visibility`
Adds or changes existing visibility specifier.
```rust
// BEFORE
2019-10-26 21:17:39 +03:00
┃fn frobnicate() {}
2019-10-26 17:37:04 +03:00
// AFTER
pub(crate) fn frobnicate() {}
```
2019-10-25 14:16:46 +03:00
## `convert_to_guarded_return`
Replace a large conditional with a guarded return.
```rust
// BEFORE
fn main() {
2019-10-26 21:17:39 +03:00
┃if cond {
2019-10-25 14:16:46 +03:00
foo();
bar();
}
}
// AFTER
fn main() {
if !cond {
return;
}
foo();
bar();
}
```
2019-10-26 17:37:04 +03:00
## `fill_match_arms`
Adds missing clauses to a `match` expression.
```rust
// BEFORE
enum Action { Move { distance: u32 }, Stop }
fn handle(action: Action) {
match action {
2019-10-26 21:17:39 +03:00
2019-10-26 17:37:04 +03:00
}
}
// AFTER
enum Action { Move { distance: u32 }, Stop }
fn handle(action: Action) {
match action {
2019-10-26 18:03:55 +03:00
Action::Move { distance } => (),
2019-10-26 17:37:04 +03:00
Action::Stop => (),
}
}
```
2019-10-26 19:08:13 +03:00
## `flip_binexpr`
Flips operands of a binary expression.
```rust
// BEFORE
fn main() {
2019-10-26 21:17:39 +03:00
let _ = 90 +┃ 2;
2019-10-26 19:08:13 +03:00
}
// AFTER
fn main() {
let _ = 2 + 90;
}
```
## `flip_comma`
Flips two comma-separated items.
```rust
// BEFORE
fn main() {
2019-10-26 21:17:39 +03:00
((1, 2),┃ (3, 4));
2019-10-26 19:08:13 +03:00
}
// AFTER
fn main() {
((3, 4), (1, 2));
}
```
## `inline_local_variable`
Inlines local variable.
```rust
// BEFORE
fn main() {
2019-10-26 21:17:39 +03:00
let x┃ = 1 + 2;
2019-10-26 19:08:13 +03:00
x * 4;
}
// AFTER
fn main() {
(1 + 2) * 4;
}
```
2019-10-26 19:58:18 +03:00
## `introduce_variable`
Extracts subexpression into a variable.
```rust
// BEFORE
fn main() {
2019-10-26 21:17:39 +03:00
┃(1 + 2)┃ * 4;
2019-10-26 19:58:18 +03:00
}
// AFTER
fn main() {
let var_name = (1 + 2);
var_name * 4;
}
```