mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-27 20:35:09 +00:00
better introduce
This commit is contained in:
parent
bb64edf8ba
commit
751562d2f7
1 changed files with 26 additions and 8 deletions
|
@ -109,17 +109,22 @@ pub fn introduce_variable<'a>(file: &'a File, range: TextRange) -> Option<impl F
|
||||||
}
|
}
|
||||||
Some(move || {
|
Some(move || {
|
||||||
let mut buf = String::new();
|
let mut buf = String::new();
|
||||||
|
let mut edit = EditBuilder::new();
|
||||||
|
|
||||||
buf.push_str("let var_name = ");
|
buf.push_str("let var_name = ");
|
||||||
expr.syntax().text().push_to(&mut buf);
|
expr.syntax().text().push_to(&mut buf);
|
||||||
|
if expr.syntax().range().start() == anchor_stmt.syntax().range().start() {
|
||||||
|
edit.replace(expr.syntax().range(), buf);
|
||||||
|
} else {
|
||||||
buf.push_str(";");
|
buf.push_str(";");
|
||||||
indent.text().push_to(&mut buf);
|
indent.text().push_to(&mut buf);
|
||||||
|
|
||||||
let mut edit = EditBuilder::new();
|
|
||||||
edit.replace(expr.syntax().range(), "var_name".to_string());
|
edit.replace(expr.syntax().range(), "var_name".to_string());
|
||||||
edit.insert(anchor_stmt.syntax().range().start(), buf);
|
edit.insert(anchor_stmt.syntax().range().start(), buf);
|
||||||
|
}
|
||||||
|
let cursor_position = anchor_stmt.syntax().range().start() + TextUnit::of_str("let ");
|
||||||
LocalEdit {
|
LocalEdit {
|
||||||
edit: edit.finish(),
|
edit: edit.finish(),
|
||||||
cursor_position: Some(anchor_stmt.syntax().range().start() + TextUnit::of_str("let ")),
|
cursor_position: Some(cursor_position),
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -183,7 +188,7 @@ mod tests {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_intrdoduce_var() {
|
fn test_intrdoduce_var_simple() {
|
||||||
check_action_range(
|
check_action_range(
|
||||||
"
|
"
|
||||||
fn foo() {
|
fn foo() {
|
||||||
|
@ -192,6 +197,19 @@ fn foo() {
|
||||||
fn foo() {
|
fn foo() {
|
||||||
let <|>var_name = 1 + 1;
|
let <|>var_name = 1 + 1;
|
||||||
foo(var_name);
|
foo(var_name);
|
||||||
|
}",
|
||||||
|
|file, range| introduce_variable(file, range).map(|f| f()),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
#[test]
|
||||||
|
fn test_intrdoduce_var_expr_stmt() {
|
||||||
|
check_action_range(
|
||||||
|
"
|
||||||
|
fn foo() {
|
||||||
|
<|>1 + 1<|>;
|
||||||
|
}", "
|
||||||
|
fn foo() {
|
||||||
|
let <|>var_name = 1 + 1;
|
||||||
}",
|
}",
|
||||||
|file, range| introduce_variable(file, range).map(|f| f()),
|
|file, range| introduce_variable(file, range).map(|f| f()),
|
||||||
);
|
);
|
||||||
|
|
Loading…
Reference in a new issue