parser: don't use unreachable!()
in fn unexpected
.
This commit is contained in:
parent
374ad1b006
commit
dcd91d5ceb
3 changed files with 33 additions and 1 deletions
|
@ -443,7 +443,9 @@ impl<'a> Parser<'a> {
|
|||
crate fn unexpected<T>(&mut self) -> PResult<'a, T> {
|
||||
match self.expect_one_of(&[], &[]) {
|
||||
Err(e) => Err(e),
|
||||
Ok(_) => unreachable!(),
|
||||
// We can get `Ok(true)` from `recover_closing_delimiter`
|
||||
// which is called in `expected_one_of_not_found`.
|
||||
Ok(_) => FatalError.raise(),
|
||||
}
|
||||
}
|
||||
|
||||
|
|
14
src/test/ui/parser/issue-66357-unexpected-unreachable.rs
Normal file
14
src/test/ui/parser/issue-66357-unexpected-unreachable.rs
Normal file
|
@ -0,0 +1,14 @@
|
|||
// The problem in #66357 was that the call trace:
|
||||
//
|
||||
// - parse_fn_block_decl
|
||||
// - expect_or
|
||||
// - unexpected
|
||||
// - expect_one_of
|
||||
// - expected_one_of_not_found
|
||||
// - recover_closing_delimiter
|
||||
//
|
||||
// ended up bubbling up `Ok(true)` to `unexpected` which then used `unreachable!()`.
|
||||
|
||||
fn f() { |[](* }
|
||||
//~^ ERROR expected one of `,` or `:`, found `(`
|
||||
//~| ERROR expected one of `)`, `-`, `_`, `box`, `mut`, `ref`, `|`, identifier, or path, found `*`
|
16
src/test/ui/parser/issue-66357-unexpected-unreachable.stderr
Normal file
16
src/test/ui/parser/issue-66357-unexpected-unreachable.stderr
Normal file
|
@ -0,0 +1,16 @@
|
|||
error: expected one of `,` or `:`, found `(`
|
||||
--> $DIR/issue-66357-unexpected-unreachable.rs:12:13
|
||||
|
|
||||
LL | fn f() { |[](* }
|
||||
| ^ expected one of `,` or `:`
|
||||
|
||||
error: expected one of `)`, `-`, `_`, `box`, `mut`, `ref`, `|`, identifier, or path, found `*`
|
||||
--> $DIR/issue-66357-unexpected-unreachable.rs:12:14
|
||||
|
|
||||
LL | fn f() { |[](* }
|
||||
| -^ help: `)` may belong here
|
||||
| |
|
||||
| unclosed delimiter
|
||||
|
||||
error: aborting due to 2 previous errors
|
||||
|
Loading…
Add table
Reference in a new issue