Skip to content

Commit

Permalink
auto merge of #12095 : FlaPer87/rust/issue-11709, r=nikomatsakis
Browse files Browse the repository at this point in the history
Closes #11709
  • Loading branch information
bors committed Feb 10, 2014
2 parents 1f245cc + 31576c7 commit cf9164f
Show file tree
Hide file tree
Showing 3 changed files with 65 additions and 7 deletions.
15 changes: 9 additions & 6 deletions src/librustc/middle/trans/base.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1506,16 +1506,19 @@ pub fn trans_closure<'a>(ccx: @CrateContext,
// emitting should be enabled.
debuginfo::start_emitting_source_locations(&fcx);

let dest = match fcx.llretptr.get() {
Some(e) => {expr::SaveIn(e)}
None => {
assert!(type_is_zero_size(bcx.ccx(), block_ty))
expr::Ignore
}
};

// This call to trans_block is the place where we bridge between
// translation calls that don't have a return value (trans_crate,
// trans_mod, trans_item, et cetera) and those that do
// (trans_block, trans_expr, et cetera).
if body.expr.is_none() || type_is_zero_size(bcx.ccx(), block_ty) {
bcx = controlflow::trans_block(bcx, body, expr::Ignore);
} else {
let dest = expr::SaveIn(fcx.llretptr.get().unwrap());
bcx = controlflow::trans_block(bcx, body, dest);
}
bcx = controlflow::trans_block(bcx, body, dest);

match fcx.llreturn.get() {
Some(_) => {
Expand Down
10 changes: 9 additions & 1 deletion src/librustc/middle/trans/controlflow.rs
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ pub fn trans_stmt<'a>(cx: &'a Block<'a>,

pub fn trans_block<'a>(bcx: &'a Block<'a>,
b: &ast::Block,
dest: expr::Dest)
mut dest: expr::Dest)
-> &'a Block<'a> {
let _icx = push_ctxt("trans_block");
let fcx = bcx.fcx;
Expand All @@ -85,6 +85,14 @@ pub fn trans_block<'a>(bcx: &'a Block<'a>,
for s in b.stmts.iter() {
bcx = trans_stmt(bcx, *s);
}

if dest != expr::Ignore {
let block_ty = node_id_type(bcx, b.id);
if b.expr.is_none() || type_is_zero_size(bcx.ccx(), block_ty) {
dest = expr::Ignore;
}
}

match b.expr {
Some(e) => {
bcx = expr::trans_into(bcx, e, dest);
Expand Down
47 changes: 47 additions & 0 deletions src/test/run-pass/issue-11709.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
// Copyright 2014 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.

// xfail-pretty

// Don't fail on blocks without results
// There are several tests in this run-pass that raised
// when this bug was oppened. The cases where the compiler
// failed before the fix have a comment.

struct S {x:()}


fn test(slot: &mut Option<proc() -> proc()>, _: proc()) -> () {
let a = slot.take();
let _a = match a {
// `{let .. a(); }` would break
Some(a) => { let _a = a(); },
None => (),
};
}

fn not(b: bool) -> bool {
if b {
!b
} else {
// `fail!(...)` would break
fail!("Break the compiler");
}
}

pub fn main() {
// {} would break
let _r = {};
let mut slot = None;
// `{ test(...); }` would break
let _s : S = S{ x: { test(&mut slot, proc() {}); } };

let _b = not(true);
}

0 comments on commit cf9164f

Please sign in to comment.