Unnamed repository; edit this file 'description' to name the repository.
-rw-r--r--crates/ide-assists/src/handlers/generate_delegate_trait.rs8
-rw-r--r--crates/syntax/src/ast/syntax_factory/constructors.rs17
2 files changed, 21 insertions, 4 deletions
diff --git a/crates/ide-assists/src/handlers/generate_delegate_trait.rs b/crates/ide-assists/src/handlers/generate_delegate_trait.rs
index 0364275621..ab350e975d 100644
--- a/crates/ide-assists/src/handlers/generate_delegate_trait.rs
+++ b/crates/ide-assists/src/handlers/generate_delegate_trait.rs
@@ -296,7 +296,7 @@ fn generate_impl(
.collect()
});
- let delegate = finalize_delegate(&delegate, assoc_items, false)?;
+ let delegate = finalize_delegate(&make, &delegate, assoc_items, false)?;
let target_scope = ctx.sema.scope(strukt.strukt.syntax())?;
let source_scope = ctx.sema.scope(bound_def.syntax())?;
@@ -406,7 +406,7 @@ fn generate_impl(
.collect()
});
- finalize_delegate(&delegate, assoc_items, true)
+ finalize_delegate(&make, &delegate, assoc_items, true)
}
}
}
@@ -552,6 +552,7 @@ fn remove_useless_where_clauses(editor: &mut SyntaxEditor, delegate: &ast::Impl)
/// 1. Replacing the assoc_item_list with new items (if any)
/// 2. Removing useless where clauses
fn finalize_delegate(
+ make: &SyntaxFactory,
delegate: &ast::Impl,
assoc_items: Option<Vec<ast::AssocItem>>,
remove_where_clauses: bool,
@@ -568,8 +569,7 @@ fn finalize_delegate(
if let Some(items) = assoc_items
&& !items.is_empty()
{
- let new_assoc_item_list =
- syntax::ast::make::assoc_item_list(Some(items)).clone_for_update();
+ let new_assoc_item_list = make.assoc_item_list(items);
if let Some(old_list) = delegate.assoc_item_list() {
editor.replace(old_list.syntax(), new_assoc_item_list.syntax());
}
diff --git a/crates/syntax/src/ast/syntax_factory/constructors.rs b/crates/syntax/src/ast/syntax_factory/constructors.rs
index 8efad0368a..560dd77662 100644
--- a/crates/syntax/src/ast/syntax_factory/constructors.rs
+++ b/crates/syntax/src/ast/syntax_factory/constructors.rs
@@ -1454,6 +1454,23 @@ impl SyntaxFactory {
ast
}
+ pub fn assoc_item_list(
+ &self,
+ items: impl IntoIterator<Item = ast::AssocItem>,
+ ) -> ast::AssocItemList {
+ let (items, input) = iterator_input(items);
+ let items_vec: Vec<_> = items.into_iter().collect();
+ let ast = make::assoc_item_list(Some(items_vec)).clone_for_update();
+
+ if let Some(mut mapping) = self.mappings() {
+ let mut builder = SyntaxMappingBuilder::new(ast.syntax().clone());
+ builder.map_children(input, ast.assoc_items().map(|item| item.syntax().clone()));
+ builder.finish(&mut mapping);
+ }
+
+ ast
+ }
+
pub fn attr_outer(&self, meta: ast::Meta) -> ast::Attr {
let ast = make::attr_outer(meta.clone()).clone_for_update();