add complex match case and documentation

This commit is contained in:
Unreal Hoang 2019-05-02 00:57:16 +09:00
parent f83e452b1e
commit d1c21b85cf
No known key found for this signature in database
GPG key ID: F66217BDC6F37CFA
2 changed files with 47 additions and 13 deletions

View file

@ -1,6 +1,4 @@
use hir::{ use hir::db::HirDatabase;
db::HirDatabase,
};
use ra_syntax::{ use ra_syntax::{
TextUnit, TextUnit,
SyntaxElement, SyntaxElement,
@ -17,9 +15,7 @@ pub(crate) fn move_guard_to_arm_body(mut ctx: AssistCtx<impl HirDatabase>) -> Op
let guard_conditions = guard.expr()?; let guard_conditions = guard.expr()?;
let arm_expr = match_arm.expr()?; let arm_expr = match_arm.expr()?;
let buf = format!("if {} {{ {} }}", let buf = format!("if {} {{ {} }}", guard_conditions.syntax().text(), arm_expr.syntax().text());
guard_conditions.syntax().text(),
arm_expr.syntax().text());
ctx.add_action(AssistId("move_guard_to_arm_body"), "move guard to arm body", |edit| { ctx.add_action(AssistId("move_guard_to_arm_body"), "move guard to arm body", |edit| {
edit.target(guard.syntax().range()); edit.target(guard.syntax().range());
@ -32,16 +28,13 @@ pub(crate) fn move_guard_to_arm_body(mut ctx: AssistCtx<impl HirDatabase>) -> Op
} else { } else {
TextUnit::from(0) TextUnit::from(0)
} }
}, }
_ => TextUnit::from(0) _ => TextUnit::from(0),
}; };
edit.delete(guard.syntax().range()); edit.delete(guard.syntax().range());
edit.replace_node_and_indent(arm_expr.syntax(), buf); edit.replace_node_and_indent(arm_expr.syntax(), buf);
edit.set_cursor( edit.set_cursor(arm_expr.syntax().range().start() + TextUnit::from(3) - offseting_amount);
arm_expr.syntax().range().start() +
TextUnit::from(3) -
offseting_amount);
}); });
ctx.build() ctx.build()
} }
@ -93,7 +86,30 @@ mod tests {
_ => true _ => true
} }
} }
"# "#,
);
}
#[test]
fn move_guard_to_arm_body_works_complex_match() {
check_assist(
move_guard_to_arm_body,
r#"
fn f() {
match x {
<|>y @ 4 | y @ 5 if y > 5 => true,
_ => false
}
}
"#,
r#"
fn f() {
match x {
y @ 4 | y @ 5 => if y > 5 { <|>true },
_ => false
}
}
"#,
); );
} }
} }

View file

@ -388,6 +388,24 @@ fn foo() {
} }
``` ```
- Move guard expression to match arm body
```rust
//before:
fn f() {
match x {
<|>y @ 4 | y @ 5 if y > 5 => true,
_ => false
}
}
//after:
fn f() {
match x {
y @ 4 | y @ 5 => if y > 5 { <|>true },
_ => false
}
}
```
### Magic Completions ### Magic Completions
In addition to usual reference completion, rust-analyzer provides some ✨magic✨ In addition to usual reference completion, rust-analyzer provides some ✨magic✨