| // build-pass (FIXME(62277): could be check-pass?) |
| |
| // ignore-tidy-linelength |
| |
| // Issue #21633: reject duplicate loop labels in function bodies. |
| // |
| // This is testing the generalization (to the whole function body) |
| // discussed here: |
| // https://internals.rust-lang.org/t/psa-rejecting-duplicate-loop-labels/1833 |
| |
| #[allow(unused_labels)] |
| pub fn foo() { |
| { 'fl: for _ in 0..10 { break; } } |
| { 'fl: loop { break; } } //~ WARN label name `'fl` shadows a label name that is already in scope |
| { 'lf: loop { break; } } |
| { 'lf: for _ in 0..10 { break; } } //~ WARN label name `'lf` shadows a label name that is already in scope |
| { 'wl: while 2 > 1 { break; } } |
| { 'wl: loop { break; } } //~ WARN label name `'wl` shadows a label name that is already in scope |
| { 'lw: loop { break; } } |
| { 'lw: while 2 > 1 { break; } } //~ WARN label name `'lw` shadows a label name that is already in scope |
| { 'fw: for _ in 0..10 { break; } } |
| { 'fw: while 2 > 1 { break; } } //~ WARN label name `'fw` shadows a label name that is already in scope |
| { 'wf: while 2 > 1 { break; } } |
| { 'wf: for _ in 0..10 { break; } } //~ WARN label name `'wf` shadows a label name that is already in scope |
| { 'tl: while let Some(_) = None::<i32> { break; } } |
| { 'tl: loop { break; } } //~ WARN label name `'tl` shadows a label name that is already in scope |
| { 'lt: loop { break; } } |
| { 'lt: while let Some(_) = None::<i32> { break; } } |
| //~^ WARN label name `'lt` shadows a label name that is already in scope |
| } |
| |
| |
| pub fn main() { |
| foo(); |
| } |