From 0758c05c9792700dbc482eda8cd464c39d5ebed5 Mon Sep 17 00:00:00 2001 From: y21 <30553356+y21@users.noreply.github.com> Date: Thu, 23 Feb 2023 20:12:01 +0100 Subject: [PATCH] recover from for-else and while-else --- compiler/rustc_parse/locales/en-US.ftl | 4 ++++ compiler/rustc_parse/src/errors.rs | 11 ++++++++++ compiler/rustc_parse/src/parser/expr.rs | 22 +++++++++++++++++++ tests/ui/for/for-else-err.rs | 8 +++++++ tests/ui/for/for-else-err.stderr | 17 ++++++++++++++ tests/ui/for/for-else-let-else-err.rs | 8 +++++++ tests/ui/for/for-else-let-else-err.stderr | 17 ++++++++++++++ .../let-else/let-else-brace-before-else.fixed | 4 ---- .../ui/let-else/let-else-brace-before-else.rs | 4 ---- .../let-else-brace-before-else.stderr | 17 +++----------- tests/ui/loops/loop-else-break-with-value.rs | 10 +++++++++ .../loops/loop-else-break-with-value.stderr | 18 +++++++++++++++ tests/ui/loops/loop-else-err.rs | 8 +++++++ tests/ui/loops/loop-else-err.stderr | 17 ++++++++++++++ tests/ui/loops/loop-else-let-else-err.rs | 8 +++++++ tests/ui/loops/loop-else-let-else-err.stderr | 17 ++++++++++++++ tests/ui/while/while-else-err.rs | 8 +++++++ tests/ui/while/while-else-err.stderr | 17 ++++++++++++++ tests/ui/while/while-else-let-else-err.rs | 8 +++++++ tests/ui/while/while-else-let-else-err.stderr | 17 ++++++++++++++ 20 files changed, 218 insertions(+), 22 deletions(-) create mode 100644 tests/ui/for/for-else-err.rs create mode 100644 tests/ui/for/for-else-err.stderr create mode 100644 tests/ui/for/for-else-let-else-err.rs create mode 100644 tests/ui/for/for-else-let-else-err.stderr create mode 100644 tests/ui/loops/loop-else-break-with-value.rs create mode 100644 tests/ui/loops/loop-else-break-with-value.stderr create mode 100644 tests/ui/loops/loop-else-err.rs create mode 100644 tests/ui/loops/loop-else-err.stderr create mode 100644 tests/ui/loops/loop-else-let-else-err.rs create mode 100644 tests/ui/loops/loop-else-let-else-err.stderr create mode 100644 tests/ui/while/while-else-err.rs create mode 100644 tests/ui/while/while-else-err.stderr create mode 100644 tests/ui/while/while-else-let-else-err.rs create mode 100644 tests/ui/while/while-else-let-else-err.stderr diff --git a/compiler/rustc_parse/locales/en-US.ftl b/compiler/rustc_parse/locales/en-US.ftl index 4ddeeed5b7e0..e76e91fc1b13 100644 --- a/compiler/rustc_parse/locales/en-US.ftl +++ b/compiler/rustc_parse/locales/en-US.ftl @@ -151,6 +151,10 @@ parse_missing_in_in_for_loop = missing `in` in `for` loop parse_missing_expression_in_for_loop = missing expression to iterate on in `for` loop .suggestion = try adding an expression to the `for` loop +parse_loop_else = `{$loop_kind}...else` loops are not supported + .note = consider moving this `else` clause to a separate `if` statement and use a `bool` variable to control if it should run + .loop_keyword = `else` is attached to this loop + parse_missing_comma_after_match_arm = expected `,` following `match` arm .suggestion = missing a comma here to end this `match` arm diff --git a/compiler/rustc_parse/src/errors.rs b/compiler/rustc_parse/src/errors.rs index c746a8709647..1662db36d10f 100644 --- a/compiler/rustc_parse/src/errors.rs +++ b/compiler/rustc_parse/src/errors.rs @@ -451,6 +451,17 @@ pub(crate) struct MissingExpressionInForLoop { pub span: Span, } +#[derive(Diagnostic)] +#[diag(parse_loop_else)] +#[note] +pub(crate) struct LoopElseNotSupported { + #[primary_span] + pub span: Span, + pub loop_kind: &'static str, + #[label(parse_loop_keyword)] + pub loop_kw: Span, +} + #[derive(Diagnostic)] #[diag(parse_missing_comma_after_match_arm)] pub(crate) struct MissingCommaAfterMatchArm { diff --git a/compiler/rustc_parse/src/parser/expr.rs b/compiler/rustc_parse/src/parser/expr.rs index 24d4c17f5d8a..b2951e7a1847 100644 --- a/compiler/rustc_parse/src/parser/expr.rs +++ b/compiler/rustc_parse/src/parser/expr.rs @@ -2503,9 +2503,27 @@ fn parse_expr_for(&mut self, opt_label: Option