Unnamed repository; edit this file 'description' to name the repository.
Diffstat (limited to 'crates/ide-assists/src/handlers/introduce_named_generic.rs')
-rw-r--r--crates/ide-assists/src/handlers/introduce_named_generic.rs49
1 files changed, 23 insertions, 26 deletions
diff --git a/crates/ide-assists/src/handlers/introduce_named_generic.rs b/crates/ide-assists/src/handlers/introduce_named_generic.rs
index bf6ac1719f..8c276415bb 100644
--- a/crates/ide-assists/src/handlers/introduce_named_generic.rs
+++ b/crates/ide-assists/src/handlers/introduce_named_generic.rs
@@ -1,9 +1,6 @@
use ide_db::syntax_helpers::suggest_name;
use itertools::Itertools;
-use syntax::{
- ast::{self, edit_in_place::GenericParamsOwnerEdit, make, AstNode, HasGenericParams, HasName},
- ted,
-};
+use syntax::ast::{self, syntax_factory::SyntaxFactory, AstNode, HasGenericParams, HasName};
use crate::{AssistContext, AssistId, AssistKind, Assists};
@@ -25,42 +22,42 @@ pub(crate) fn introduce_named_generic(acc: &mut Assists, ctx: &AssistContext<'_>
let type_bound_list = impl_trait_type.type_bound_list()?;
+ let make = SyntaxFactory::new();
let target = fn_.syntax().text_range();
acc.add(
AssistId("introduce_named_generic", AssistKind::RefactorRewrite),
"Replace impl trait with generic",
target,
- |edit| {
- let impl_trait_type = edit.make_mut(impl_trait_type);
- let fn_ = edit.make_mut(fn_);
- let fn_generic_param_list = fn_.get_or_create_generic_param_list();
-
- let existing_names = fn_generic_param_list
- .generic_params()
- .flat_map(|param| match param {
- ast::GenericParam::TypeParam(t) => t.name().map(|name| name.to_string()),
- p => Some(p.to_string()),
- })
- .collect_vec();
+ |builder| {
+ let mut editor = builder.make_editor(fn_.syntax());
+
+ let existing_names = match fn_.generic_param_list() {
+ Some(generic_param_list) => generic_param_list
+ .generic_params()
+ .flat_map(|param| match param {
+ ast::GenericParam::TypeParam(t) => t.name().map(|name| name.to_string()),
+ p => Some(p.to_string()),
+ })
+ .collect_vec(),
+ None => Vec::new(),
+ };
let type_param_name = suggest_name::NameGenerator::new_with_names(
existing_names.iter().map(|s| s.as_str()),
)
.for_impl_trait_as_generic(&impl_trait_type);
- let type_param = make::type_param(make::name(&type_param_name), Some(type_bound_list))
- .clone_for_update();
- let new_ty = make::ty(&type_param_name).clone_for_update();
+ let type_param = make.type_param(make.name(&type_param_name), Some(type_bound_list));
+ let new_ty = make.ty(&type_param_name);
- ted::replace(impl_trait_type.syntax(), new_ty.syntax());
- fn_generic_param_list.add_generic_param(type_param.into());
+ editor.replace(impl_trait_type.syntax(), new_ty.syntax());
+ editor.add_generic_param(&fn_, type_param.clone().into());
if let Some(cap) = ctx.config.snippet_cap {
- if let Some(generic_param) =
- fn_.generic_param_list().and_then(|it| it.generic_params().last())
- {
- edit.add_tabstop_before(cap, generic_param);
- }
+ editor.add_annotation(type_param.syntax(), builder.make_tabstop_before(cap));
}
+
+ editor.add_mappings(make.finish_with_mappings());
+ builder.add_file_edits(ctx.file_id(), editor);
},
)
}