blob: 53874e9528efee875ba29702007cc3f06f6e7e78 [file] [log] [blame]
// unit-test: GVN
// FIXME(wesleywiser): Ideally, we could const-prop away all of this and just be left with
// `let x = 42` but that doesn't work because const-prop doesn't support `Operand::Indirect`
// and `InterpCx::eval_place()` always forces an allocation which creates the `Indirect`.
// Fixing either of those will allow us to const-prop this away.
// EMIT_MIR_FOR_EACH_BIT_WIDTH
// EMIT_MIR discriminant.main.GVN.diff
fn main() {
// CHECK-LABEL: fn main(
// CHECK: bb0: {
// CHECK: switchInt(const 1_isize) -> [1: bb1, otherwise: bb3];
// CHECK: bb1: {
// CHECK: switchInt(const true) -> [0: bb3, otherwise: bb2];
// CHECK: bb2: {
// CHECK: [[tmp:_.*]] = const 42_i32;
// CHECK: goto -> bb4;
// CHECK: bb3: {
// CHECK: [[tmp]] = const 10_i32;
// CHECK: goto -> bb4;
// CHECK: bb4: {
// CHECK: {{_.*}} = Add(move [[tmp]], const 0_i32);
let x = (if let Some(true) = Some(true) { 42 } else { 10 }) + 0;
}