Auto merge of #12384 - fasterthanlime:gh-12372, r=Veykril

Generate variant: insert code in file with enum definition

Closes #12372
This commit is contained in:
bors 2022-05-25 14:49:51 +00:00
commit 0468d84564

View file

@ -1,4 +1,4 @@
use hir::HasSource; use hir::{HasSource, InFile};
use ide_db::assists::{AssistId, AssistKind}; use ide_db::assists::{AssistId, AssistKind};
use syntax::{ use syntax::{
ast::{self, edit::IndentLevel}, ast::{self, edit::IndentLevel},
@ -63,10 +63,11 @@ fn add_variant_to_accumulator(
adt: hir::Enum, adt: hir::Enum,
name_ref: &ast::NameRef, name_ref: &ast::NameRef,
) -> Option<()> { ) -> Option<()> {
let adt_ast = adt.source(ctx.db())?.original_ast_node(ctx.db())?.value; let db = ctx.db();
let enum_indent = IndentLevel::from_node(&adt_ast.syntax()); let InFile { file_id, value: enum_node } = adt.source(db)?.original_ast_node(db)?;
let enum_indent = IndentLevel::from_node(&enum_node.syntax());
let variant_list = adt_ast.variant_list()?; let variant_list = enum_node.variant_list()?;
let offset = variant_list.syntax().text_range().end() - TextSize::of('}'); let offset = variant_list.syntax().text_range().end() - TextSize::of('}');
let empty_enum = variant_list.variants().next().is_none(); let empty_enum = variant_list.variants().next().is_none();
@ -75,6 +76,7 @@ fn add_variant_to_accumulator(
"Generate variant", "Generate variant",
target, target,
|builder| { |builder| {
builder.edit_file(file_id.original_file(db));
let text = format!( let text = format!(
"{maybe_newline}{indent_1}{name},\n{enum_indent}", "{maybe_newline}{indent_1}{name},\n{enum_indent}",
maybe_newline = if empty_enum { "\n" } else { "" }, maybe_newline = if empty_enum { "\n" } else { "" },