mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-28 04:45:05 +00:00
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:
commit
1093803e38
1 changed files with 27 additions and 2 deletions
|
@ -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 }
|
||||||
|
|
||||||
"#,
|
"#,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue