Unnamed repository; edit this file 'description' to name the repository.
Diffstat (limited to 'crates/ide-assists/src/handlers/extract_struct_from_enum_variant.rs')
-rw-r--r--crates/ide-assists/src/handlers/extract_struct_from_enum_variant.rs48
1 files changed, 22 insertions, 26 deletions
diff --git a/crates/ide-assists/src/handlers/extract_struct_from_enum_variant.rs b/crates/ide-assists/src/handlers/extract_struct_from_enum_variant.rs
index 6975789b98..3272fa739f 100644
--- a/crates/ide-assists/src/handlers/extract_struct_from_enum_variant.rs
+++ b/crates/ide-assists/src/handlers/extract_struct_from_enum_variant.rs
@@ -60,7 +60,8 @@ pub(crate) fn extract_struct_from_enum_variant(
"Extract struct from enum variant",
target,
|builder| {
- let mut editor = builder.make_editor(variant.syntax());
+ let editor = builder.make_editor(variant.syntax());
+ let make = editor.make();
let edition = enum_hir.krate(ctx.db()).edition(ctx.db());
let variant_hir_name = variant_hir.name(ctx.db());
let enum_module_def = ModuleDef::from(enum_hir);
@@ -86,7 +87,7 @@ pub(crate) fn extract_struct_from_enum_variant(
if processed.is_empty() {
continue;
}
- let mut file_editor = builder.make_editor(processed[0].0.syntax());
+ let file_editor = builder.make_editor(processed[0].0.syntax());
processed.into_iter().for_each(|(path, node, import)| {
apply_references(
ctx.config.insert_use,
@@ -94,7 +95,7 @@ pub(crate) fn extract_struct_from_enum_variant(
node,
import,
edition,
- &mut file_editor,
+ &file_editor,
)
});
builder.add_file_edits(file_id.file_id(ctx.db()), file_editor);
@@ -109,19 +110,12 @@ pub(crate) fn extract_struct_from_enum_variant(
references,
);
processed.into_iter().for_each(|(path, node, import)| {
- apply_references(
- ctx.config.insert_use,
- path,
- node,
- import,
- edition,
- &mut editor,
- )
+ apply_references(ctx.config.insert_use, path, node, import, edition, &editor)
});
}
let generic_params = enum_ast.generic_param_list().and_then(|known_generics| {
- extract_generic_params(editor.make(), &known_generics, &field_list)
+ extract_generic_params(make, &known_generics, &field_list)
});
// resolve GenericArg in field_list to actual type
@@ -144,13 +138,13 @@ pub(crate) fn extract_struct_from_enum_variant(
};
let (comments_for_struct, comments_to_delete) =
- collect_variant_comments(editor.make(), variant.syntax());
+ collect_variant_comments(make, variant.syntax());
for element in &comments_to_delete {
editor.delete(element.clone());
}
let def = create_struct_def(
- editor.make(),
+ make,
variant_name.clone(),
&field_list,
generic_params.clone(),
@@ -164,14 +158,14 @@ pub(crate) fn extract_struct_from_enum_variant(
let mut insert_items: Vec<SyntaxElement> = Vec::new();
for attr in enum_ast.attrs() {
insert_items.push(attr.syntax().clone().into());
- insert_items.push(editor.make().whitespace("\n").into());
+ insert_items.push(make.whitespace("\n").into());
}
insert_items.extend(comments_for_struct);
insert_items.push(def.syntax().clone().into());
- insert_items.push(editor.make().whitespace(&format!("\n\n{indent}")).into());
+ insert_items.push(make.whitespace(&format!("\n\n{indent}")).into());
editor.insert_all_with_whitespace(Position::before(enum_ast.syntax()), insert_items);
- update_variant(&mut editor, &variant, generic_params);
+ update_variant(&editor, &variant, generic_params);
builder.add_file_edits(ctx.vfs_file_id(), editor);
},
@@ -331,23 +325,24 @@ fn create_struct_def(
}
fn update_variant(
- editor: &mut SyntaxEditor,
+ editor: &SyntaxEditor,
variant: &ast::Variant,
generics: Option<ast::GenericParamList>,
) -> Option<()> {
+ let make = editor.make();
let name = variant.name()?;
let generic_args = generics
.filter(|generics| generics.generic_params().count() > 0)
.map(|generics| generics.to_generic_args());
// FIXME: replace with a `ast::make` constructor
let ty = match generic_args {
- Some(generic_args) => editor.make().ty(&format!("{name}{generic_args}")),
- None => editor.make().ty(&name.text()),
+ Some(generic_args) => make.ty(&format!("{name}{generic_args}")),
+ None => make.ty(&name.text()),
};
// change from a record to a tuple field list
- let tuple_field = editor.make().tuple_field(None, ty);
- let field_list = editor.make().tuple_field_list(iter::once(tuple_field));
+ let tuple_field = make.tuple_field(None, ty);
+ let field_list = make.tuple_field_list(iter::once(tuple_field));
editor.replace(variant.field_list()?.syntax(), field_list.syntax());
// remove any ws after the name
@@ -397,16 +392,17 @@ fn apply_references(
node: SyntaxNode,
import: Option<(ImportScope, hir::ModPath)>,
edition: Edition,
- editor: &mut SyntaxEditor,
+ editor: &SyntaxEditor,
) {
+ let make = editor.make();
if let Some((scope, path)) = import {
insert_use_with_editor(&scope, mod_path_to_ast(&path, edition), &insert_use_cfg, editor);
}
// deep clone to prevent cycle
- let path = editor.make().path_from_segments(iter::once(segment.clone()), false);
- editor.insert(Position::before(segment.syntax()), editor.make().token(T!['(']));
+ let path = make.path_from_segments(iter::once(segment.clone()), false);
+ editor.insert(Position::before(segment.syntax()), make.token(T!['(']));
editor.insert(Position::before(segment.syntax()), path.syntax());
- editor.insert(Position::after(&node), editor.make().token(T![')']));
+ editor.insert(Position::after(&node), make.token(T![')']));
}
fn process_references(