53 lines
1 KiB
Diff
53 lines
1 KiB
Diff
- // MIR for `foo` before MatchBranchSimplification
|
|
+ // MIR for `foo` after MatchBranchSimplification
|
|
|
|
fn foo(_1: Option<()>) -> () {
|
|
debug bar => _1;
|
|
let mut _0: ();
|
|
let mut _2: bool;
|
|
let mut _3: isize;
|
|
+ let mut _4: isize;
|
|
|
|
bb0: {
|
|
StorageLive(_2);
|
|
_3 = discriminant(_1);
|
|
- switchInt(move _3) -> [0: bb2, otherwise: bb1];
|
|
+ StorageLive(_4);
|
|
+ _4 = move _3;
|
|
+ _2 = Eq(copy _4, const 0_isize);
|
|
+ StorageDead(_4);
|
|
+ switchInt(move _2) -> [0: bb2, otherwise: bb1];
|
|
}
|
|
|
|
bb1: {
|
|
- _2 = const false;
|
|
+ _0 = ();
|
|
goto -> bb3;
|
|
}
|
|
|
|
bb2: {
|
|
- _2 = const true;
|
|
+ _0 = const ();
|
|
goto -> bb3;
|
|
}
|
|
|
|
bb3: {
|
|
- switchInt(move _2) -> [0: bb5, otherwise: bb4];
|
|
- }
|
|
-
|
|
- bb4: {
|
|
- _0 = ();
|
|
- goto -> bb6;
|
|
- }
|
|
-
|
|
- bb5: {
|
|
- _0 = const ();
|
|
- goto -> bb6;
|
|
- }
|
|
-
|
|
- bb6: {
|
|
StorageDead(_2);
|
|
return;
|
|
}
|
|
}
|
|
|