Rollup merge of #69180 - Aaron1011:feature/comma-struct-init, r=petrochenkov
Suggest a comma if a struct initializer field fails to parse Currently, we emit a "try adding a comma" suggestion if a comma is missing in a struct definition. However, we emit no such suggestion if a comma is missing in a struct initializer. This commit adds a "try adding a comma" suggestion when we don't find a comma during the parsing of a struct initializer field. The change to `src/test/ui/parser/removed-syntax-with-1.stderr` isn't great, but I don't see a good way of avoiding it.
This commit is contained in:
commit
e9db0613ac
4 changed files with 46 additions and 3 deletions
|
@ -1832,10 +1832,16 @@ impl<'a> Parser<'a> {
|
|||
}
|
||||
}
|
||||
Err(mut e) => {
|
||||
e.span_label(struct_sp, "while parsing this struct");
|
||||
if let Some(f) = recovery_field {
|
||||
fields.push(f);
|
||||
e.span_suggestion(
|
||||
self.prev_span.shrink_to_hi(),
|
||||
"try adding a comma",
|
||||
",".into(),
|
||||
Applicability::MachineApplicable,
|
||||
);
|
||||
}
|
||||
e.span_label(struct_sp, "while parsing this struct");
|
||||
e.emit();
|
||||
self.recover_stmt_(SemiColonMode::Comma, BlockMode::Ignore);
|
||||
self.eat(&token::Comma);
|
||||
|
|
|
@ -2,8 +2,9 @@ error: expected one of `,`, `.`, `?`, `}`, or an operator, found `with`
|
|||
--> $DIR/removed-syntax-with-1.rs:8:25
|
||||
|
|
||||
LL | let b = S { foo: () with a, bar: () };
|
||||
| - ^^^^ expected one of `,`, `.`, `?`, `}`, or an operator
|
||||
| |
|
||||
| - -^^^^ expected one of `,`, `.`, `?`, `}`, or an operator
|
||||
| | |
|
||||
| | help: try adding a comma: `,`
|
||||
| while parsing this struct
|
||||
|
||||
error: aborting due to previous error
|
||||
|
|
13
src/test/ui/suggestions/struct-initializer-comma.rs
Normal file
13
src/test/ui/suggestions/struct-initializer-comma.rs
Normal file
|
@ -0,0 +1,13 @@
|
|||
struct Foo {
|
||||
first: bool,
|
||||
second: u8,
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let a = Foo {
|
||||
//~^ ERROR missing field
|
||||
first: true
|
||||
second: 25
|
||||
//~^ ERROR expected one of
|
||||
};
|
||||
}
|
23
src/test/ui/suggestions/struct-initializer-comma.stderr
Normal file
23
src/test/ui/suggestions/struct-initializer-comma.stderr
Normal file
|
@ -0,0 +1,23 @@
|
|||
error: expected one of `,`, `.`, `?`, `}`, or an operator, found `second`
|
||||
--> $DIR/struct-initializer-comma.rs:10:9
|
||||
|
|
||||
LL | let a = Foo {
|
||||
| --- while parsing this struct
|
||||
LL |
|
||||
LL | first: true
|
||||
| -
|
||||
| |
|
||||
| expected one of `,`, `.`, `?`, `}`, or an operator
|
||||
| help: try adding a comma: `,`
|
||||
LL | second: 25
|
||||
| ^^^^^^ unexpected token
|
||||
|
||||
error[E0063]: missing field `second` in initializer of `Foo`
|
||||
--> $DIR/struct-initializer-comma.rs:7:13
|
||||
|
|
||||
LL | let a = Foo {
|
||||
| ^^^ missing `second`
|
||||
|
||||
error: aborting due to 2 previous errors
|
||||
|
||||
For more information about this error, try `rustc --explain E0063`.
|
Loading…
Add table
Add a link
Reference in a new issue