Fix "consider removing this semicolon" help

Check last statement in a block, not the first
This commit is contained in:
Jonas Schievink 2016-04-03 22:10:21 +02:00
parent c0b8c43820
commit 0163ccc36b
2 changed files with 19 additions and 2 deletions

View file

@ -1502,7 +1502,7 @@ impl<'a, 'tcx> Liveness<'a, 'tcx> {
} else { } else {
let ends_with_stmt = match body.expr { let ends_with_stmt = match body.expr {
None if !body.stmts.is_empty() => None if !body.stmts.is_empty() =>
match body.stmts.first().unwrap().node { match body.stmts.last().unwrap().node {
hir::StmtSemi(ref e, _) => { hir::StmtSemi(ref e, _) => {
self.ir.tcx.expr_ty(&e) == t_ret self.ir.tcx.expr_ty(&e) == t_ret
}, },
@ -1515,7 +1515,7 @@ impl<'a, 'tcx> Liveness<'a, 'tcx> {
E0269, E0269,
"not all control paths return a value"); "not all control paths return a value");
if ends_with_stmt { if ends_with_stmt {
let last_stmt = body.stmts.first().unwrap(); let last_stmt = body.stmts.last().unwrap();
let original_span = original_sp(self.ir.tcx.sess.codemap(), let original_span = original_sp(self.ir.tcx.sess.codemap(),
last_stmt.span, sp); last_stmt.span, sp);
let span_semicolon = Span { let span_semicolon = Span {

View file

@ -0,0 +1,17 @@
// Copyright 2016 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.
fn f() -> String { //~ ERROR E0269
//~^ HELP detailed explanation
0u8;
"bla".to_string(); //~ HELP consider removing this semicolon
}
fn main() {}