mirror of
https://github.com/rust-lang/rust.git
synced 2026-04-27 18:57:42 +03:00
f5d3b158b9
This prevents spurious errors when a field is intended to be present
but a preceding syntax error caused it not to be parsed. For example,
StructName { foo: 1 bar: 2 }
will not successfully parse a field `bar`, and we will report the syntax
error but not the missing field.
39 lines
1021 B
Rust
39 lines
1021 B
Rust
// Check that a syntax error inside a struct literal does not also report missing fields,
|
|
// because the field might be present but hidden by the syntax error.
|
|
//
|
|
// The stderr for this test should contain ONLY one syntax error per struct literal,
|
|
// and not any errors about missing fields.
|
|
|
|
struct Foo { a: isize, b: isize }
|
|
|
|
fn make_a() -> isize { 1234 }
|
|
|
|
fn expr_wrong_separator() {
|
|
let f = Foo { a: make_a(); b: 2 }; //~ ERROR found `;`
|
|
}
|
|
|
|
fn expr_missing_separator() {
|
|
let f = Foo { a: make_a() b: 2 }; //~ ERROR found `b`
|
|
}
|
|
|
|
fn expr_rest_trailing_comma() {
|
|
let f = Foo { a: make_a(), ..todo!(), }; //~ ERROR cannot use a comma
|
|
}
|
|
|
|
fn expr_missing_field_name() {
|
|
let f = Foo { make_a(), b: 2, }; //~ ERROR found `(`
|
|
}
|
|
|
|
fn pat_wrong_separator(Foo { a; b }: Foo) { //~ ERROR expected `,`
|
|
let _ = (a, b);
|
|
}
|
|
|
|
fn pat_missing_separator(Foo { a b }: Foo) { //~ ERROR expected `,`
|
|
let _ = (a, b);
|
|
}
|
|
|
|
fn pat_rest_trailing_comma(Foo { a, .., }: Foo) { //~ ERROR expected `}`, found `,`
|
|
}
|
|
|
|
fn main() {}
|