diff options
| author | sjwang05 <63834813+sjwang05@users.noreply.github.com> | 2023-11-09 00:31:42 -0800 |
|---|---|---|
| committer | sjwang05 <63834813+sjwang05@users.noreply.github.com> | 2023-11-09 00:31:42 -0800 |
| commit | 5693a34db2f0e929995fe7aa03d307bafa9360aa (patch) | |
| tree | 5e971a5ee3634a67832cd0b9f12f3fc63362b284 /compiler/rustc_parse/src/parser/expr.rs | |
| parent | d8dbf7ca0ee9c6da0fd039b1eb8cf7c7cb840f43 (diff) | |
| download | rust-5693a34db2f0e929995fe7aa03d307bafa9360aa.tar.gz rust-5693a34db2f0e929995fe7aa03d307bafa9360aa.zip | |
Suggest fix for ; within let-chains
Diffstat (limited to 'compiler/rustc_parse/src/parser/expr.rs')
| -rw-r--r-- | compiler/rustc_parse/src/parser/expr.rs | 24 |
1 files changed, 20 insertions, 4 deletions
diff --git a/compiler/rustc_parse/src/parser/expr.rs b/compiler/rustc_parse/src/parser/expr.rs index 19690a6964b..235b28b6e26 100644 --- a/compiler/rustc_parse/src/parser/expr.rs +++ b/compiler/rustc_parse/src/parser/expr.rs @@ -2441,10 +2441,26 @@ impl<'a> Parser<'a> { self.error_on_extra_if(&cond)?; // Parse block, which will always fail, but we can add a nice note to the error self.parse_block().map_err(|mut err| { - err.span_note( - cond_span, - "the `if` expression is missing a block after this condition", - ); + if self.prev_token == token::Semi + && self.token == token::AndAnd + && let maybe_let = self.look_ahead(1, |t| t.clone()) + && maybe_let.is_keyword(kw::Let) + { + err.span_suggestion( + self.prev_token.span, + "consider removing this semicolon to parse the `let` as part of the same chain", + "", + Applicability::MachineApplicable, + ).span_note( + self.token.span.to(maybe_let.span), + "you likely meant to continue parsing the let-chain starting here", + ); + } else { + err.span_note( + cond_span, + "the `if` expression is missing a block after this condition", + ); + } err })? } |
