rust/tests/mir-opt/building/match_false_edges.full_tested_match2.built.after.mir

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

129 lines
2.4 KiB
Rust
Raw Normal View History

// MIR for `full_tested_match2` after built
2020-04-02 21:09:01 +00:00
fn full_tested_match2() -> () {
2023-06-06 09:47:00 -04:00
let mut _0: ();
let mut _1: (i32, i32);
let mut _2: std::option::Option<i32>;
let mut _3: isize;
let mut _4: &std::option::Option<i32>;
let _5: i32;
let _6: &i32;
let mut _7: bool;
let mut _8: i32;
let _9: i32;
let mut _10: i32;
2020-04-02 21:09:01 +00:00
scope 1 {
}
scope 2 {
2023-06-06 09:47:00 -04:00
debug x => _5;
debug x => _6;
2020-04-02 21:09:01 +00:00
}
scope 3 {
2023-06-06 09:47:00 -04:00
debug y => _9;
2020-04-02 21:09:01 +00:00
}
bb0: {
2023-06-06 09:47:00 -04:00
StorageLive(_1);
StorageLive(_2);
_2 = Option::<i32>::Some(const 42_i32);
PlaceMention(_2);
2023-06-06 09:47:00 -04:00
_3 = discriminant(_2);
2024-02-16 02:57:24 +01:00
switchInt(move _3) -> [0: bb2, 1: bb4, otherwise: bb1];
2020-04-02 21:09:01 +00:00
}
2020-10-02 16:11:24 -04:00
bb1: {
2024-02-12 04:56:03 +01:00
FakeRead(ForMatchedPlace(None), _2);
unreachable;
2020-04-02 21:09:01 +00:00
}
bb2: {
2024-02-16 02:57:24 +01:00
falseEdge -> [real: bb12, imaginary: bb5];
2020-04-02 21:09:01 +00:00
}
bb3: {
2024-02-16 02:57:24 +01:00
goto -> bb1;
2024-02-12 04:56:03 +01:00
}
bb4: {
2024-02-16 02:57:24 +01:00
falseEdge -> [real: bb7, imaginary: bb2];
}
bb5: {
2023-06-06 09:47:00 -04:00
StorageLive(_9);
_9 = ((_2 as Some).0: i32);
StorageLive(_10);
_10 = _9;
_1 = (const 2_i32, move _10);
StorageDead(_10);
StorageDead(_9);
2024-02-16 02:57:24 +01:00
goto -> bb13;
2020-04-02 21:09:01 +00:00
}
2024-02-16 02:57:24 +01:00
bb6: {
goto -> bb1;
}
bb7: {
2023-06-06 09:47:00 -04:00
StorageLive(_6);
_6 = &((_2 as Some).0: i32);
2023-11-08 18:38:30 +01:00
_4 = &fake _2;
2023-06-06 09:47:00 -04:00
StorageLive(_7);
2024-02-16 02:57:24 +01:00
_7 = guard() -> [return: bb8, unwind: bb16];
2020-04-02 21:09:01 +00:00
}
2024-02-16 02:57:24 +01:00
bb8: {
switchInt(move _7) -> [0: bb10, otherwise: bb9];
2020-04-02 21:09:01 +00:00
}
2024-02-16 02:57:24 +01:00
bb9: {
2023-06-06 09:47:00 -04:00
StorageDead(_7);
FakeRead(ForMatchGuard, _4);
FakeRead(ForGuardBinding, _6);
StorageLive(_5);
_5 = ((_2 as Some).0: i32);
StorageLive(_8);
_8 = _5;
_1 = (const 1_i32, move _8);
StorageDead(_8);
StorageDead(_5);
StorageDead(_6);
2024-02-16 02:57:24 +01:00
goto -> bb13;
2020-04-02 21:09:01 +00:00
}
2024-02-16 02:57:24 +01:00
bb10: {
goto -> bb11;
}
2024-02-16 02:57:24 +01:00
bb11: {
2023-06-06 09:47:00 -04:00
StorageDead(_7);
StorageDead(_6);
2024-02-16 02:57:24 +01:00
falseEdge -> [real: bb5, imaginary: bb2];
2020-04-02 21:09:01 +00:00
}
2024-02-16 02:57:24 +01:00
bb12: {
2023-06-06 09:47:00 -04:00
_1 = (const 3_i32, const 3_i32);
2024-02-16 02:57:24 +01:00
goto -> bb13;
2020-04-02 21:09:01 +00:00
}
2024-02-16 02:57:24 +01:00
bb13: {
2023-06-06 09:47:00 -04:00
PlaceMention(_1);
StorageDead(_2);
StorageDead(_1);
_0 = const ();
return;
2020-04-02 21:09:01 +00:00
}
2020-10-02 16:11:24 -04:00
2024-02-16 02:57:24 +01:00
bb14: {
2024-02-12 04:56:03 +01:00
FakeRead(ForMatchedPlace(None), _1);
unreachable;
}
2024-02-16 02:57:24 +01:00
bb15: {
goto -> bb14;
}
bb16 (cleanup): {
2023-06-06 09:47:00 -04:00
resume;
2020-10-02 16:11:24 -04:00
}
2020-04-02 21:09:01 +00:00
}