Unnamed repository; edit this file 'description' to name the repository.
Merge pull request #21993 from Shourya742/2026-04-08-remove-generate-trait-from-impl
Remove make with SyntaxFactory in generate_trait_from_impl
Chayim Refael Friedman 6 weeks ago
parent ea8c16c · parent 20c47a9 · commit 4fac9df
-rw-r--r--crates/ide-assists/src/handlers/generate_trait_from_impl.rs13
-rw-r--r--crates/syntax/src/ast/syntax_factory/constructors.rs41
2 files changed, 49 insertions, 5 deletions
diff --git a/crates/ide-assists/src/handlers/generate_trait_from_impl.rs b/crates/ide-assists/src/handlers/generate_trait_from_impl.rs
index 2255560900..2d3d05849b 100644
--- a/crates/ide-assists/src/handlers/generate_trait_from_impl.rs
+++ b/crates/ide-assists/src/handlers/generate_trait_from_impl.rs
@@ -4,6 +4,7 @@ use syntax::{
AstNode, AstToken, SyntaxKind, T,
ast::{
self, HasDocComments, HasGenericParams, HasName, HasVisibility, edit::AstNodeEdit, make,
+ syntax_factory::SyntaxFactory,
},
syntax_editor::{Position, SyntaxEditor},
};
@@ -107,17 +108,18 @@ pub(crate) fn generate_trait_from_impl(acc: &mut Assists, ctx: &AssistContext<'_
});
ast::AssocItemList::cast(trait_items_editor.finish().new_root().clone()).unwrap()
};
- let trait_ast = make::trait_(
+
+ let factory = SyntaxFactory::with_mappings();
+ let trait_ast = factory.trait_(
false,
&trait_name(&impl_assoc_items).text(),
impl_ast.generic_param_list(),
impl_ast.where_clause(),
trait_items,
- )
- .clone_for_update();
+ );
let trait_name = trait_ast.name().expect("new trait should have a name");
- let trait_name_ref = make::name_ref(&trait_name.to_string()).clone_for_update();
+ let trait_name_ref = factory.name_ref(&trait_name.to_string());
// Change `impl Foo` to `impl NewTrait for Foo`
let mut elements = vec![
@@ -128,7 +130,7 @@ pub(crate) fn generate_trait_from_impl(acc: &mut Assists, ctx: &AssistContext<'_
];
if let Some(params) = impl_ast.generic_param_list() {
- let gen_args = &params.to_generic_args().clone_for_update();
+ let gen_args = &params.to_generic_args();
elements.insert(1, gen_args.syntax().clone().into());
}
@@ -156,6 +158,7 @@ pub(crate) fn generate_trait_from_impl(acc: &mut Assists, ctx: &AssistContext<'_
editor.add_annotation(trait_name_ref.syntax(), placeholder);
}
+ editor.add_mappings(factory.finish_with_mappings());
builder.add_file_edits(ctx.vfs_file_id(), editor);
},
);
diff --git a/crates/syntax/src/ast/syntax_factory/constructors.rs b/crates/syntax/src/ast/syntax_factory/constructors.rs
index 44ab64d4f6..e91e444a32 100644
--- a/crates/syntax/src/ast/syntax_factory/constructors.rs
+++ b/crates/syntax/src/ast/syntax_factory/constructors.rs
@@ -1960,6 +1960,47 @@ impl SyntaxFactory {
ast
}
+ pub fn trait_(
+ &self,
+ is_unsafe: bool,
+ ident: &str,
+ generic_param_list: Option<ast::GenericParamList>,
+ where_clause: Option<ast::WhereClause>,
+ assoc_items: ast::AssocItemList,
+ ) -> ast::Trait {
+ let ast = make::trait_(
+ is_unsafe,
+ ident,
+ generic_param_list.clone(),
+ where_clause.clone(),
+ assoc_items.clone(),
+ )
+ .clone_for_update();
+
+ if let Some(mut mapping) = self.mappings() {
+ let mut builder = SyntaxMappingBuilder::new(ast.syntax().clone());
+ if let Some(generic_param_list) = generic_param_list {
+ builder.map_node(
+ generic_param_list.syntax().clone(),
+ ast.generic_param_list().unwrap().syntax().clone(),
+ );
+ }
+ if let Some(where_clause) = where_clause {
+ builder.map_node(
+ where_clause.syntax().clone(),
+ ast.where_clause().unwrap().syntax().clone(),
+ );
+ }
+ builder.map_node(
+ assoc_items.syntax().clone(),
+ ast.assoc_item_list().unwrap().syntax().clone(),
+ );
+ builder.finish(&mut mapping);
+ }
+
+ ast
+ }
+
pub fn ret_type(&self, ty: ast::Type) -> ast::RetType {
let ast = make::ret_type(ty.clone()).clone_for_update();