diff options
| author | kennytm <kennytm@gmail.com> | 2018-02-02 16:29:16 +0800 |
|---|---|---|
| committer | kennytm <kennytm@gmail.com> | 2018-02-02 22:48:41 +0800 |
| commit | 0f36b2cf2e406535b38908b6a081b5d7b06258d9 (patch) | |
| tree | 4f47116fe58dbc74c247fd063cf494ab6be8ff87 | |
| parent | 3600bfb3f021f63fc1065ff4e706ff4b70e57e09 (diff) | |
| parent | b7437c56f82cfb643a372a7b10c85b4ed183d886 (diff) | |
| download | rust-0f36b2cf2e406535b38908b6a081b5d7b06258d9.tar.gz rust-0f36b2cf2e406535b38908b6a081b5d7b06258d9.zip | |
Rollup merge of #47829 - estebank:break-in-for, r=cramertj Suggest removing value from `break` when invalid When attempting to use `break` with a value in a type of loop where it'd be invalid (any non-`loop`), suggest using `break` on its own. Close #34359.
| -rw-r--r-- | src/librustc_passes/loops.rs | 5 | ||||
| -rw-r--r-- | src/test/ui/loop-break-value-no-repeat.stderr | 4 |
2 files changed, 9 insertions, 0 deletions
diff --git a/src/librustc_passes/loops.rs b/src/librustc_passes/loops.rs index c23f28fe220..008c71cc9ce 100644 --- a/src/librustc_passes/loops.rs +++ b/src/librustc_passes/loops.rs @@ -119,6 +119,11 @@ impl<'a, 'hir> Visitor<'hir> for CheckLoopVisitor<'a, 'hir> { kind.name()) .span_label(e.span, "can only break with a value inside `loop`") + .span_suggestion(e.span, + &format!("instead, use `break` on its own \ + without a value inside this `{}` loop", + kind.name()), + "break".to_string()) .emit(); } } diff --git a/src/test/ui/loop-break-value-no-repeat.stderr b/src/test/ui/loop-break-value-no-repeat.stderr index 296b3b191e3..982de00b4fa 100644 --- a/src/test/ui/loop-break-value-no-repeat.stderr +++ b/src/test/ui/loop-break-value-no-repeat.stderr @@ -3,6 +3,10 @@ error[E0571]: `break` with value from a `for` loop | 22 | break 22 //~ ERROR `break` with value from a `for` loop | ^^^^^^^^ can only break with a value inside `loop` +help: instead, use `break` on its own without a value inside this `for` loop + | +22 | break //~ ERROR `break` with value from a `for` loop + | ^^^^^ error: aborting due to previous error |
