aboutsummaryrefslogtreecommitdiff
path: root/src/comp
diff options
context:
space:
mode:
authorBrian Anderson <[email protected]>2011-04-02 13:55:29 -0400
committerBrian Anderson <[email protected]>2011-04-02 20:35:50 -0400
commit9d0a505d61e77d6186631552065438aa04944b12 (patch)
tree4524ae64dae8c696f08a137dcdc2a4dfbbf02d70 /src/comp
parentWrite typarams for variants. Typecheck gets as far as ty.rs now. (diff)
downloadrust-9d0a505d61e77d6186631552065438aa04944b12.tar.xz
rust-9d0a505d61e77d6186631552065438aa04944b12.zip
Terminate fail blocks by making their ends unreachable.
This will make implementing default alt arms simpler.
Diffstat (limited to 'src/comp')
-rw-r--r--src/comp/middle/trans.rs6
1 files changed, 3 insertions, 3 deletions
diff --git a/src/comp/middle/trans.rs b/src/comp/middle/trans.rs
index b9ebc167..5b4a08f3 100644
--- a/src/comp/middle/trans.rs
+++ b/src/comp/middle/trans.rs
@@ -3852,7 +3852,6 @@ fn trans_index(@block_ctxt cx, &ast.span sp, @ast.expr base,
// fail: bad bounds check.
auto fail_res = trans_fail(fail_cx, sp, "bounds check");
- fail_res.bcx.build.Br(next_cx.llbb);
auto body = next_cx.build.GEP(v, vec(C_int(0), C_int(abi.vec_elt_data)));
auto elt;
@@ -4916,7 +4915,6 @@ fn trans_check_expr(@block_ctxt cx, @ast.expr e) -> result {
auto fail_res = trans_fail(fail_cx, e.span, expr_str);
auto next_cx = new_sub_block_ctxt(cx, "next");
- fail_res.bcx.build.Br(next_cx.llbb);
cond_res.bcx.build.CondBr(cond_res.val,
next_cx.llbb,
fail_cx.llbb);
@@ -4929,7 +4927,9 @@ fn trans_fail(@block_ctxt cx, common.span sp, str fail_str) -> result {
auto V_line = sp.lo.line as int;
auto args = vec(V_fail_str, V_filename, C_int(V_line));
- ret trans_upcall(cx, "upcall_fail", args);
+ auto sub = trans_upcall(cx, "upcall_fail", args);
+ sub.bcx.build.Unreachable();
+ ret res(sub.bcx, C_nil());
}
fn trans_put(@block_ctxt cx, &option.t[@ast.expr] e) -> result {