Rollup merge of #59453 - estebank:recover-tuple-parse, r=petrochenkov
Recover from parse error in tuple syntax
This commit is contained in:
commit
c28704c2a8
13 changed files with 228 additions and 34 deletions
|
|
@ -1,5 +1,5 @@
|
|||
fn main() {
|
||||
match 0 {
|
||||
match (0, 1) {
|
||||
(, ..) => {} //~ ERROR expected pattern, found `,`
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,5 +1,5 @@
|
|||
fn main() {
|
||||
match 0 {
|
||||
match (0, 1) {
|
||||
(pat ..) => {} //~ ERROR unexpected token: `)`
|
||||
}
|
||||
}
|
||||
|
|
|
|||
14
src/test/ui/parser/recover-from-bad-variant.rs
Normal file
14
src/test/ui/parser/recover-from-bad-variant.rs
Normal file
|
|
@ -0,0 +1,14 @@
|
|||
enum Enum {
|
||||
Foo { a: usize, b: usize },
|
||||
Bar(usize, usize),
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let x = Enum::Foo(a: 3, b: 4);
|
||||
//~^ ERROR expected type, found `3`
|
||||
match x {
|
||||
Enum::Foo(a, b) => {}
|
||||
//~^ ERROR expected tuple struct/variant, found struct variant `Enum::Foo`
|
||||
Enum::Bar(a, b) => {}
|
||||
}
|
||||
}
|
||||
23
src/test/ui/parser/recover-from-bad-variant.stderr
Normal file
23
src/test/ui/parser/recover-from-bad-variant.stderr
Normal file
|
|
@ -0,0 +1,23 @@
|
|||
error: expected type, found `3`
|
||||
--> $DIR/recover-from-bad-variant.rs:7:26
|
||||
|
|
||||
LL | let x = Enum::Foo(a: 3, b: 4);
|
||||
| ^ expecting a type here because of type ascription
|
||||
|
|
||||
= note: type ascription is a nightly-only feature that lets you annotate an expression with a type: `<expr>: <type>`
|
||||
note: this expression expects an ascribed type after the colon
|
||||
--> $DIR/recover-from-bad-variant.rs:7:23
|
||||
|
|
||||
LL | let x = Enum::Foo(a: 3, b: 4);
|
||||
| ^
|
||||
= help: this might be indicative of a syntax error elsewhere
|
||||
|
||||
error[E0532]: expected tuple struct/variant, found struct variant `Enum::Foo`
|
||||
--> $DIR/recover-from-bad-variant.rs:10:9
|
||||
|
|
||||
LL | Enum::Foo(a, b) => {}
|
||||
| ^^^^^^^^^ did you mean `Enum::Foo { /* fields */ }`?
|
||||
|
||||
error: aborting due to 2 previous errors
|
||||
|
||||
For more information about this error, try `rustc --explain E0532`.
|
||||
12
src/test/ui/parser/recover-tuple-pat.rs
Normal file
12
src/test/ui/parser/recover-tuple-pat.rs
Normal file
|
|
@ -0,0 +1,12 @@
|
|||
fn main() {
|
||||
let x = (1, 2, 3, 4);
|
||||
match x {
|
||||
(1, .., 4) => {}
|
||||
(1, .=., 4) => { let _: usize = ""; }
|
||||
//~^ ERROR expected pattern, found `.`
|
||||
//~| ERROR mismatched types
|
||||
(.=., 4) => {}
|
||||
//~^ ERROR expected pattern, found `.`
|
||||
(1, 2, 3, 4) => {}
|
||||
}
|
||||
}
|
||||
24
src/test/ui/parser/recover-tuple-pat.stderr
Normal file
24
src/test/ui/parser/recover-tuple-pat.stderr
Normal file
|
|
@ -0,0 +1,24 @@
|
|||
error: expected pattern, found `.`
|
||||
--> $DIR/recover-tuple-pat.rs:5:13
|
||||
|
|
||||
LL | (1, .=., 4) => { let _: usize = ""; }
|
||||
| ^ expected pattern
|
||||
|
||||
error: expected pattern, found `.`
|
||||
--> $DIR/recover-tuple-pat.rs:8:10
|
||||
|
|
||||
LL | (.=., 4) => {}
|
||||
| ^ expected pattern
|
||||
|
||||
error[E0308]: mismatched types
|
||||
--> $DIR/recover-tuple-pat.rs:5:41
|
||||
|
|
||||
LL | (1, .=., 4) => { let _: usize = ""; }
|
||||
| ^^ expected usize, found reference
|
||||
|
|
||||
= note: expected type `usize`
|
||||
found type `&'static str`
|
||||
|
||||
error: aborting due to 3 previous errors
|
||||
|
||||
For more information about this error, try `rustc --explain E0308`.
|
||||
11
src/test/ui/parser/recover-tuple.rs
Normal file
11
src/test/ui/parser/recover-tuple.rs
Normal file
|
|
@ -0,0 +1,11 @@
|
|||
fn main() {
|
||||
// no complaints about the tuple not matching the expected type
|
||||
let x: (usize, usize, usize) = (3, .=.);
|
||||
//~^ ERROR expected expression, found `.`
|
||||
// verify that the parser recovers:
|
||||
let y: usize = ""; //~ ERROR mismatched types
|
||||
// no complaints about the type
|
||||
foo(x);
|
||||
}
|
||||
|
||||
fn foo(_: (usize, usize, usize)) {}
|
||||
18
src/test/ui/parser/recover-tuple.stderr
Normal file
18
src/test/ui/parser/recover-tuple.stderr
Normal file
|
|
@ -0,0 +1,18 @@
|
|||
error: expected expression, found `.`
|
||||
--> $DIR/recover-tuple.rs:3:40
|
||||
|
|
||||
LL | let x: (usize, usize, usize) = (3, .=.);
|
||||
| ^ expected expression
|
||||
|
||||
error[E0308]: mismatched types
|
||||
--> $DIR/recover-tuple.rs:6:20
|
||||
|
|
||||
LL | let y: usize = "";
|
||||
| ^^ expected usize, found reference
|
||||
|
|
||||
= note: expected type `usize`
|
||||
found type `&'static str`
|
||||
|
||||
error: aborting due to 2 previous errors
|
||||
|
||||
For more information about this error, try `rustc --explain E0308`.
|
||||
|
|
@ -6,7 +6,10 @@ fn f<'a, T: Trait + ('a)>() {} //~ ERROR parenthesized lifetime bounds are not s
|
|||
|
||||
fn check<'a>() {
|
||||
let _: Box<Trait + ('a)>; //~ ERROR parenthesized lifetime bounds are not supported
|
||||
let _: Box<('a) + Trait>; //~ ERROR expected type, found `'a`
|
||||
let _: Box<('a) + Trait>;
|
||||
//~^ ERROR expected type, found `'a`
|
||||
//~| ERROR expected `:`, found `)`
|
||||
//~| ERROR chained comparison operators require parentheses
|
||||
}
|
||||
|
||||
fn main() {}
|
||||
|
|
|
|||
|
|
@ -10,6 +10,21 @@ error: parenthesized lifetime bounds are not supported
|
|||
LL | let _: Box<Trait + ('a)>;
|
||||
| ^^^^ help: remove the parentheses
|
||||
|
||||
error: expected `:`, found `)`
|
||||
--> $DIR/trait-object-lifetime-parens.rs:9:19
|
||||
|
|
||||
LL | let _: Box<('a) + Trait>;
|
||||
| ^ expected `:`
|
||||
|
||||
error: chained comparison operators require parentheses
|
||||
--> $DIR/trait-object-lifetime-parens.rs:9:15
|
||||
|
|
||||
LL | let _: Box<('a) + Trait>;
|
||||
| ^^^^^^^^^^^^^^^
|
||||
|
|
||||
= help: use `::<...>` instead of `<...>` if you meant to specify type arguments
|
||||
= help: or use `(...)` if you meant to specify fn arguments
|
||||
|
||||
error: expected type, found `'a`
|
||||
--> $DIR/trait-object-lifetime-parens.rs:9:17
|
||||
|
|
||||
|
|
@ -18,5 +33,5 @@ LL | let _: Box<('a) + Trait>;
|
|||
| |
|
||||
| while parsing the type for `_`
|
||||
|
||||
error: aborting due to 3 previous errors
|
||||
error: aborting due to 5 previous errors
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue