about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2017-12-21 16:15:16 +0000
committerbors <bors@rust-lang.org>2017-12-21 16:15:16 +0000
commitb7b52cc8bf2bcc4cbd223a4b61fe3e35e798f6e2 (patch)
treeb7e406e6dd07ffd6ad43ab619c06ca550f669e26 /src
parenteff3de0927c36e6483ccb8a35c3d2da6e063de0b (diff)
parent8dfc47a4c9728ae7edcfb6a51515af00db994641 (diff)
downloadrust-b7b52cc8bf2bcc4cbd223a4b61fe3e35e798f6e2.tar.gz
rust-b7b52cc8bf2bcc4cbd223a4b61fe3e35e798f6e2.zip
Auto merge of #46877 - Deewiant:gh46843, r=eddyb
MIR: terminate unreachable blocks in construct_const

Fixes #46843.

#45821 added unreachable blocks in matches, which were terminated in
construct_fn but not in construct_const, causing a panic due to "no
terminator on block" when constants involved matching on enums.

The "unimplemented expression type" error may go away in the future, the
key is that we see the E0015 about using a non-const function and then
don't ICE.
Diffstat (limited to 'src')
-rw-r--r--src/librustc_mir/build/mod.rs7
-rw-r--r--src/test/compile-fail/issue-46843.rs22
2 files changed, 29 insertions, 0 deletions
diff --git a/src/librustc_mir/build/mod.rs b/src/librustc_mir/build/mod.rs
index d814b092c9d..51ebb78c74e 100644
--- a/src/librustc_mir/build/mod.rs
+++ b/src/librustc_mir/build/mod.rs
@@ -472,6 +472,13 @@ fn construct_const<'a, 'gcx, 'tcx>(hir: Cx<'a, 'gcx, 'tcx>,
     // Constants can't `return` so a return block should not be created.
     assert_eq!(builder.cached_return_block, None);
 
+    // Constants may be match expressions in which case an unreachable block may
+    // be created, so terminate it properly.
+    if let Some(unreachable_block) = builder.cached_unreachable_block {
+        builder.cfg.terminate(unreachable_block, source_info,
+                              TerminatorKind::Unreachable);
+    }
+
     builder.finish(vec![], None)
 }
 
diff --git a/src/test/compile-fail/issue-46843.rs b/src/test/compile-fail/issue-46843.rs
new file mode 100644
index 00000000000..d88b4e568b0
--- /dev/null
+++ b/src/test/compile-fail/issue-46843.rs
@@ -0,0 +1,22 @@
+// Copyright 2017 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.
+
+enum Thing { This, That }
+
+fn non_const() -> Thing {
+    Thing::This
+}
+
+pub const Q: i32 = match non_const() { //~ ERROR E0015
+    Thing::This => 1, //~ ERROR unimplemented expression type
+    Thing::That => 0
+};
+
+fn main() {}