Skip to content

Commit

Permalink
Auto merge of #46877 - Deewiant:gh46843, r=eddyb
Browse files Browse the repository at this point in the history
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.
  • Loading branch information
bors committed Dec 21, 2017
2 parents eff3de0 + 8dfc47a commit b7b52cc
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 0 deletions.
7 changes: 7 additions & 0 deletions src/librustc_mir/build/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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)
}

Expand Down
22 changes: 22 additions & 0 deletions src/test/compile-fail/issue-46843.rs
Original file line number Diff line number Diff line change
@@ -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() {}

0 comments on commit b7b52cc

Please sign in to comment.