Unnamed repository; edit this file 'description' to name the repository.
Diffstat (limited to 'crates/syntax/src/syntax_editor/edit_algo.rs')
-rw-r--r--crates/syntax/src/syntax_editor/edit_algo.rs16
1 files changed, 6 insertions, 10 deletions
diff --git a/crates/syntax/src/syntax_editor/edit_algo.rs b/crates/syntax/src/syntax_editor/edit_algo.rs
index b769c94110..71b69dbec1 100644
--- a/crates/syntax/src/syntax_editor/edit_algo.rs
+++ b/crates/syntax/src/syntax_editor/edit_algo.rs
@@ -73,7 +73,7 @@ pub(super) fn apply_edits(editor: SyntaxEditor) -> SyntaxEdit {
})
.all(|(l, r)| {
get_node_depth(l.target_parent()) != get_node_depth(r.target_parent())
- || l.target_range().intersect(r.target_range()).is_none()
+ || (l.target_range().end() <= r.target_range().start())
});
if stdx::never!(
@@ -128,13 +128,14 @@ pub(super) fn apply_edits(editor: SyntaxEditor) -> SyntaxEdit {
// Add to changed ancestors, if applicable
match change {
- Change::Insert(_, _) | Change::InsertAll(_, _) => {}
- Change::Replace(target, _) | Change::ReplaceWithMany(target, _) => {
+ Change::Replace(SyntaxElement::Node(target), _)
+ | Change::ReplaceWithMany(SyntaxElement::Node(target), _) => {
changed_ancestors.push_back(ChangedAncestor::single(target, change_index))
}
Change::ReplaceAll(range, _) => {
changed_ancestors.push_back(ChangedAncestor::multiple(range, change_index))
}
+ _ => (),
}
}
@@ -304,13 +305,8 @@ enum ChangedAncestorKind {
}
impl ChangedAncestor {
- fn single(element: &SyntaxElement, change_index: usize) -> Self {
- let kind = match element {
- SyntaxElement::Node(node) => ChangedAncestorKind::Single { node: node.clone() },
- SyntaxElement::Token(token) => {
- ChangedAncestorKind::Single { node: token.parent().unwrap() }
- }
- };
+ fn single(node: &SyntaxNode, change_index: usize) -> Self {
+ let kind = ChangedAncestorKind::Single { node: node.clone() };
Self { kind, change_index }
}