]> git.lizzy.rs Git - rust.git/commitdiff
Fix broken codegen for [expr; n] where "expr" diverges
authorBjörn Steinbrink <bsteinbr@gmail.com>
Sat, 14 Mar 2015 13:21:43 +0000 (14:21 +0100)
committerBjörn Steinbrink <bsteinbr@gmail.com>
Sat, 14 Mar 2015 13:23:43 +0000 (14:23 +0100)
src/librustc_trans/trans/tvec.rs
src/test/run-fail/issue-23354-2.rs [new file with mode: 0644]

index 6ed45211084e3189be458affe27fcb3547ddebc5..2fd79c1ddb48d9fc285fb11c0f96a283330339bf 100644 (file)
@@ -410,8 +410,12 @@ pub fn iter_vec_loop<'blk, 'tcx, F>(bcx: Block<'blk, 'tcx>,
     F: FnOnce(Block<'blk, 'tcx>, ValueRef, Ty<'tcx>) -> Block<'blk, 'tcx>,
 {
     let _icx = push_ctxt("tvec::iter_vec_loop");
-    let fcx = bcx.fcx;
 
+    if bcx.unreachable.get() {
+        return bcx;
+    }
+
+    let fcx = bcx.fcx;
     let loop_bcx = fcx.new_temp_block("expr_repeat");
     let next_bcx = fcx.new_temp_block("expr_repeat: next");
 
diff --git a/src/test/run-fail/issue-23354-2.rs b/src/test/run-fail/issue-23354-2.rs
new file mode 100644 (file)
index 0000000..b120d32
--- /dev/null
@@ -0,0 +1,17 @@
+// Copyright 2015 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.
+
+// error-pattern:panic evaluated
+
+#[allow(unused_variables)]
+fn main() {
+    // This used to trigger an LLVM assertion during compilation
+    let x = [panic!("panic evaluated"); 2];
+}