diff options
| author | bors <bors@rust-lang.org> | 2015-12-18 17:06:19 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2015-12-18 17:06:19 +0000 |
| commit | 29ea4eef9fa6e36f40bc1f31eb1e56bf5941ee72 (patch) | |
| tree | 342d236063310071de07c681a41a60899c24d4ef /src | |
| parent | 33916307780495fe311fe9c080b330d266f35bfb (diff) | |
| parent | e0a526015da284588dba24bf9446636d50bfbf81 (diff) | |
| download | rust-29ea4eef9fa6e36f40bc1f31eb1e56bf5941ee72.tar.gz rust-29ea4eef9fa6e36f40bc1f31eb1e56bf5941ee72.zip | |
Auto merge of #30374 - durka:issue-30371, r=alexcrichton
Fixes #30371.
Diffstat (limited to 'src')
| -rw-r--r-- | src/librustc_front/lowering.rs | 5 | ||||
| -rw-r--r-- | src/test/run-pass/issue-30371.rs | 18 |
2 files changed, 21 insertions, 2 deletions
diff --git a/src/librustc_front/lowering.rs b/src/librustc_front/lowering.rs index db30ee9a5d2..136c25f425e 100644 --- a/src/librustc_front/lowering.rs +++ b/src/librustc_front/lowering.rs @@ -1502,8 +1502,9 @@ pub fn lower_expr(lctx: &LoweringContext, e: &Expr) -> P<hir::Expr> { hir::MatchSource::ForLoopDesugar, None); - // `{ let result = ...; result }` - let result_ident = lctx.str_to_ident("result"); + // `{ let _result = ...; _result }` + // underscore prevents an unused_variables lint if the head diverges + let result_ident = lctx.str_to_ident("_result"); let let_stmt = stmt_let(lctx, e.span, false, result_ident, match_expr, None); let result = expr_ident(lctx, e.span, result_ident, None); let block = block_all(lctx, e.span, hir_vec![let_stmt], Some(result)); diff --git a/src/test/run-pass/issue-30371.rs b/src/test/run-pass/issue-30371.rs new file mode 100644 index 00000000000..a4ab475e9ea --- /dev/null +++ b/src/test/run-pass/issue-30371.rs @@ -0,0 +1,18 @@ +// Copyright 2012 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +#![deny(unused_variables)] + +fn main() { + for _ in match return () { + () => Some(0), + } {} +} + |
