Auto merge of #17867 - ShoyuVanilla:issue-17854, r=Veykril

fix: Trailing excess comma in "Convert to named struct" assist

Fixes #17854
This commit is contained in:
bors 2024-08-13 06:24:19 +00:00
commit 1093803e38

View file

@ -2,7 +2,7 @@ use either::Either;
use ide_db::defs::{Definition, NameRefClass}; use ide_db::defs::{Definition, NameRefClass};
use syntax::{ use syntax::{
ast::{self, AstNode, HasGenericParams, HasVisibility}, ast::{self, AstNode, HasGenericParams, HasVisibility},
match_ast, SyntaxNode, match_ast, SyntaxKind, SyntaxNode,
}; };
use crate::{assist_context::SourceChangeBuilder, AssistContext, AssistId, AssistKind, Assists}; use crate::{assist_context::SourceChangeBuilder, AssistContext, AssistId, AssistKind, Assists};
@ -100,7 +100,9 @@ fn edit_struct_def(
ast::make::tokens::single_newline().text(), ast::make::tokens::single_newline().text(),
); );
edit.insert(tuple_fields_text_range.start(), w.syntax().text()); edit.insert(tuple_fields_text_range.start(), w.syntax().text());
if !w.syntax().last_token().is_some_and(|t| t.kind() == SyntaxKind::COMMA) {
edit.insert(tuple_fields_text_range.start(), ","); edit.insert(tuple_fields_text_range.start(), ",");
}
edit.insert( edit.insert(
tuple_fields_text_range.start(), tuple_fields_text_range.start(),
ast::make::tokens::single_newline().text(), ast::make::tokens::single_newline().text(),
@ -879,6 +881,29 @@ use crate::{A::Variant, Inner};
fn f() { fn f() {
let a = Variant { field1: Inner }; let a = Variant { field1: Inner };
} }
"#,
);
}
#[test]
fn where_clause_with_trailing_comma() {
check_assist(
convert_tuple_struct_to_named_struct,
r#"
trait Foo {}
struct Bar$0<T>(pub T)
where
T: Foo,;
"#,
r#"
trait Foo {}
struct Bar<T>
where
T: Foo,
{ pub field1: T }
"#, "#,
); );
} }