Skip to content

Commit 11fc5da

Browse files
committed
Migrate pull_assignment_up assist to SyntaxEditor
Signed-off-by: Hayashi Mikihiro <34ttrweoewiwe28@gmail.com>
1 parent 9a1fc3c commit 11fc5da

File tree

4 files changed

+32
-19
lines changed

4 files changed

+32
-19
lines changed

crates/ide-assists/src/handlers/generate_getter_or_setter.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -294,7 +294,7 @@ fn generate_setter_from_info(info: &AssistInfo, record_field_info: &RecordFieldI
294294
let self_expr = make::ext::expr_self();
295295
let lhs = make::expr_field(self_expr, field_name);
296296
let rhs = make::expr_path(make::ext::ident_path(field_name));
297-
let assign_stmt = make::expr_stmt(make::expr_assignment(lhs, rhs));
297+
let assign_stmt = make::expr_stmt(make::expr_assignment(lhs, rhs).into());
298298
let body = make::block_expr([assign_stmt.into()], None);
299299

300300
// Make the setter fn

crates/ide-assists/src/handlers/pull_assignment_up.rs

Lines changed: 17 additions & 17 deletions
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
use syntax::{
22
AstNode,
3-
ast::{self, make},
4-
ted,
3+
algo::find_node_at_offset,
4+
ast::{self, syntax_factory::SyntaxFactory},
55
};
66

77
use crate::{
@@ -66,33 +66,33 @@ pub(crate) fn pull_assignment_up(acc: &mut Assists, ctx: &AssistContext<'_>) ->
6666
return None;
6767
}
6868
}
69-
69+
let target = tgt.syntax().text_range();
7070
acc.add(
7171
AssistId::refactor_extract("pull_assignment_up"),
7272
"Pull assignment up",
73-
tgt.syntax().text_range(),
73+
target,
7474
move |edit| {
75-
let assignments: Vec<_> = collector
76-
.assignments
77-
.into_iter()
78-
.map(|(stmt, rhs)| (edit.make_mut(stmt), rhs.clone_for_update()))
79-
.collect();
80-
81-
let tgt = edit.make_mut(tgt);
82-
83-
for (stmt, rhs) in assignments {
75+
let mut editor = edit.make_editor(tgt.syntax());
76+
for (stmt, rhs) in collector.assignments {
8477
let mut stmt = stmt.syntax().clone();
8578
if let Some(parent) = stmt.parent() {
8679
if ast::ExprStmt::cast(parent.clone()).is_some() {
8780
stmt = parent.clone();
8881
}
8982
}
90-
ted::replace(stmt, rhs.syntax());
83+
editor.replace(stmt, rhs.syntax());
9184
}
92-
let assign_expr = make::expr_assignment(collector.common_lhs, tgt.clone());
93-
let assign_stmt = make::expr_stmt(assign_expr);
85+
let new_tgt_root = editor.finish().new_root().clone();
86+
let new_tgt = find_node_at_offset::<ast::Expr>(&new_tgt_root, target.start()).unwrap();
87+
88+
let make = SyntaxFactory::with_mappings();
89+
let mut editor = edit.make_editor(tgt.syntax());
90+
let assign_expr = make.expr_assignment(collector.common_lhs, new_tgt.clone());
91+
let assign_stmt = make.expr_stmt(assign_expr.into());
9492

95-
ted::replace(tgt.syntax(), assign_stmt.syntax().clone_for_update());
93+
editor.replace(tgt.syntax(), assign_stmt.syntax());
94+
editor.add_mappings(make.finish_with_mappings());
95+
edit.add_file_edits(ctx.vfs_file_id(), editor);
9696
},
9797
)
9898
}

crates/syntax/src/ast/make.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -680,7 +680,7 @@ pub fn expr_tuple(elements: impl IntoIterator<Item = ast::Expr>) -> ast::TupleEx
680680
let expr = elements.into_iter().format(", ");
681681
expr_from_text(&format!("({expr})"))
682682
}
683-
pub fn expr_assignment(lhs: ast::Expr, rhs: ast::Expr) -> ast::Expr {
683+
pub fn expr_assignment(lhs: ast::Expr, rhs: ast::Expr) -> ast::BinExpr {
684684
expr_from_text(&format!("{lhs} = {rhs}"))
685685
}
686686
fn expr_from_text<E: Into<ast::Expr> + AstNode>(text: &str) -> E {

crates/syntax/src/ast/syntax_factory/constructors.rs

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -440,6 +440,19 @@ impl SyntaxFactory {
440440
ast
441441
}
442442

443+
pub fn expr_assignment(&self, lhs: ast::Expr, rhs: ast::Expr) -> ast::BinExpr {
444+
let ast = make::expr_assignment(lhs.clone(), rhs.clone()).clone_for_update();
445+
446+
if let Some(mut mapping) = self.mappings() {
447+
let mut builder = SyntaxMappingBuilder::new(ast.syntax().clone());
448+
builder.map_node(lhs.syntax().clone(), ast.lhs().unwrap().syntax().clone());
449+
builder.map_node(rhs.syntax().clone(), ast.rhs().unwrap().syntax().clone());
450+
builder.finish(&mut mapping);
451+
}
452+
453+
ast
454+
}
455+
443456
pub fn expr_bin(&self, lhs: ast::Expr, op: ast::BinaryOp, rhs: ast::Expr) -> ast::BinExpr {
444457
let ast::Expr::BinExpr(ast) =
445458
make::expr_bin_op(lhs.clone(), op, rhs.clone()).clone_for_update()

0 commit comments

Comments
 (0)