mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-14 06:03:58 +00:00
fix: Map new replacement nodes to their mutable equivalents in SyntaxEditor
This commit is contained in:
parent
4c755e62a6
commit
e66b4f336d
7 changed files with 22 additions and 20 deletions
|
@ -52,9 +52,8 @@ pub(crate) fn flip_binexpr(acc: &mut Assists, ctx: &AssistContext<'_>) -> Option
|
||||||
if let FlipAction::FlipAndReplaceOp(binary_op) = action {
|
if let FlipAction::FlipAndReplaceOp(binary_op) = action {
|
||||||
editor.replace(op_token, make.token(binary_op))
|
editor.replace(op_token, make.token(binary_op))
|
||||||
};
|
};
|
||||||
// FIXME: remove `clone_for_update` when `SyntaxEditor` handles it for us
|
editor.replace(lhs.syntax(), rhs.syntax());
|
||||||
editor.replace(lhs.syntax(), rhs.syntax().clone_for_update());
|
editor.replace(rhs.syntax(), lhs.syntax());
|
||||||
editor.replace(rhs.syntax(), lhs.syntax().clone_for_update());
|
|
||||||
editor.add_mappings(make.finish_with_mappings());
|
editor.add_mappings(make.finish_with_mappings());
|
||||||
builder.add_file_edits(ctx.file_id(), editor);
|
builder.add_file_edits(ctx.file_id(), editor);
|
||||||
},
|
},
|
||||||
|
|
|
@ -39,13 +39,12 @@ pub(crate) fn flip_comma(acc: &mut Assists, ctx: &AssistContext<'_>) -> Option<(
|
||||||
return None;
|
return None;
|
||||||
}
|
}
|
||||||
|
|
||||||
// FIXME: remove `clone_for_update` when `SyntaxEditor` handles it for us
|
|
||||||
let prev = match prev {
|
let prev = match prev {
|
||||||
SyntaxElement::Node(node) => node.clone_for_update().syntax_element(),
|
SyntaxElement::Node(node) => node.syntax_element(),
|
||||||
_ => prev,
|
_ => prev,
|
||||||
};
|
};
|
||||||
let next = match next {
|
let next = match next {
|
||||||
SyntaxElement::Node(node) => node.clone_for_update().syntax_element(),
|
SyntaxElement::Node(node) => node.syntax_element(),
|
||||||
_ => next,
|
_ => next,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -37,8 +37,8 @@ pub(crate) fn flip_trait_bound(acc: &mut Assists, ctx: &AssistContext<'_>) -> Op
|
||||||
target,
|
target,
|
||||||
|builder| {
|
|builder| {
|
||||||
let mut editor = builder.make_editor(parent.syntax());
|
let mut editor = builder.make_editor(parent.syntax());
|
||||||
editor.replace(before.clone(), after.clone_for_update());
|
editor.replace(before.clone(), after.clone());
|
||||||
editor.replace(after.clone(), before.clone_for_update());
|
editor.replace(after, before);
|
||||||
builder.add_file_edits(ctx.file_id(), editor);
|
builder.add_file_edits(ctx.file_id(), editor);
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
|
@ -92,10 +92,9 @@ fn replace<T: AstNode + PartialEq>(
|
||||||
fields: impl Iterator<Item = T>,
|
fields: impl Iterator<Item = T>,
|
||||||
sorted_fields: impl IntoIterator<Item = T>,
|
sorted_fields: impl IntoIterator<Item = T>,
|
||||||
) {
|
) {
|
||||||
fields.zip(sorted_fields).for_each(|(field, sorted_field)| {
|
fields
|
||||||
// FIXME: remove `clone_for_update` when `SyntaxEditor` handles it for us
|
.zip(sorted_fields)
|
||||||
editor.replace(field.syntax(), sorted_field.syntax().clone_for_update())
|
.for_each(|(field, sorted_field)| editor.replace(field.syntax(), sorted_field.syntax()));
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn compute_fields_ranks(
|
fn compute_fields_ranks(
|
||||||
|
|
|
@ -101,10 +101,10 @@ pub(crate) fn reorder_impl_items(acc: &mut Assists, ctx: &AssistContext<'_>) ->
|
||||||
|builder| {
|
|builder| {
|
||||||
let mut editor = builder.make_editor(&parent_node);
|
let mut editor = builder.make_editor(&parent_node);
|
||||||
|
|
||||||
assoc_items.into_iter().zip(sorted).for_each(|(old, new)| {
|
assoc_items
|
||||||
// FIXME: remove `clone_for_update` when `SyntaxEditor` handles it for us
|
.into_iter()
|
||||||
editor.replace(old.syntax(), new.clone_for_update().syntax())
|
.zip(sorted)
|
||||||
});
|
.for_each(|(old, new)| editor.replace(old.syntax(), new.syntax()));
|
||||||
|
|
||||||
builder.add_file_edits(ctx.file_id(), editor);
|
builder.add_file_edits(ctx.file_id(), editor);
|
||||||
},
|
},
|
||||||
|
|
|
@ -133,10 +133,9 @@ impl AddRewrite for Assists {
|
||||||
|builder| {
|
|builder| {
|
||||||
let mut editor = builder.make_editor(target);
|
let mut editor = builder.make_editor(target);
|
||||||
|
|
||||||
old.into_iter().zip(new).for_each(|(old, new)| {
|
old.into_iter()
|
||||||
// FIXME: remove `clone_for_update` when `SyntaxEditor` handles it for us
|
.zip(new)
|
||||||
editor.replace(old.syntax(), new.clone_for_update().syntax())
|
.for_each(|(old, new)| editor.replace(old.syntax(), new.syntax()));
|
||||||
});
|
|
||||||
|
|
||||||
builder.add_file_edits(builder.file_id, editor)
|
builder.add_file_edits(builder.file_id, editor)
|
||||||
},
|
},
|
||||||
|
|
|
@ -155,6 +155,12 @@ pub(super) fn apply_edits(editor: SyntaxEditor) -> SyntaxEdit {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
Change::Replace(SyntaxElement::Node(target), Some(SyntaxElement::Node(new_target))) => {
|
||||||
|
*target = tree_mutator.make_syntax_mut(target);
|
||||||
|
if new_target.ancestors().any(|node| node == tree_mutator.immutable) {
|
||||||
|
*new_target = new_target.clone_for_update();
|
||||||
|
}
|
||||||
|
}
|
||||||
Change::Replace(target, _) | Change::ReplaceWithMany(target, _) => {
|
Change::Replace(target, _) | Change::ReplaceWithMany(target, _) => {
|
||||||
*target = tree_mutator.make_element_mut(target);
|
*target = tree_mutator.make_element_mut(target);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue