4668123945
To reproduce the changes in this commit locally: - Run `./x test tidy` and remove all the output files not associated with a test file anymore, as reported by tidy. - Run `./x test tests/mir-opt --bless` to generate the new outputs.
75 lines
4 KiB
Diff
75 lines
4 KiB
Diff
- // MIR for `main` before ElaborateDrops
|
|
+ // MIR for `main` after ElaborateDrops
|
|
|
|
fn main() -> () {
|
|
let mut _0: (); // return place in scope 0 at $DIR/issue_41110.rs:+0:11: +0:11
|
|
let _1: (); // in scope 0 at $DIR/issue_41110.rs:+1:9: +1:10
|
|
let mut _2: S; // in scope 0 at $DIR/issue_41110.rs:+1:13: +1:14
|
|
let mut _3: S; // in scope 0 at $DIR/issue_41110.rs:+1:21: +1:27
|
|
let mut _4: S; // in scope 0 at $DIR/issue_41110.rs:+1:21: +1:22
|
|
+ let mut _5: bool; // in scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
|
|
scope 1 {
|
|
debug x => _1; // in scope 1 at $DIR/issue_41110.rs:+1:9: +1:10
|
|
}
|
|
|
|
bb0: {
|
|
+ _5 = const false; // scope 0 at $DIR/issue_41110.rs:+1:9: +1:10
|
|
StorageLive(_1); // scope 0 at $DIR/issue_41110.rs:+1:9: +1:10
|
|
StorageLive(_2); // scope 0 at $DIR/issue_41110.rs:+1:13: +1:14
|
|
+ _5 = const true; // scope 0 at $DIR/issue_41110.rs:+1:13: +1:14
|
|
_2 = S; // scope 0 at $DIR/issue_41110.rs:+1:13: +1:14
|
|
StorageLive(_3); // scope 0 at $DIR/issue_41110.rs:+1:21: +1:27
|
|
StorageLive(_4); // scope 0 at $DIR/issue_41110.rs:+1:21: +1:22
|
|
_4 = S; // scope 0 at $DIR/issue_41110.rs:+1:21: +1:22
|
|
_3 = S::id(move _4) -> [return: bb1, unwind: bb4]; // scope 0 at $DIR/issue_41110.rs:+1:21: +1:27
|
|
// mir::Constant
|
|
// + span: $DIR/issue_41110.rs:8:23: 8:25
|
|
// + literal: Const { ty: fn(S) -> S {S::id}, val: Value(<ZST>) }
|
|
}
|
|
|
|
bb1: {
|
|
StorageDead(_4); // scope 0 at $DIR/issue_41110.rs:+1:26: +1:27
|
|
+ _5 = const false; // scope 0 at $DIR/issue_41110.rs:+1:13: +1:28
|
|
_1 = S::other(move _2, move _3) -> [return: bb2, unwind: bb3]; // scope 0 at $DIR/issue_41110.rs:+1:13: +1:28
|
|
// mir::Constant
|
|
// + span: $DIR/issue_41110.rs:8:15: 8:20
|
|
// + literal: Const { ty: fn(S, S) {S::other}, val: Value(<ZST>) }
|
|
}
|
|
|
|
bb2: {
|
|
StorageDead(_3); // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
|
|
+ _5 = const false; // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
|
|
StorageDead(_2); // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
|
|
_0 = const (); // scope 0 at $DIR/issue_41110.rs:+0:11: +2:2
|
|
StorageDead(_1); // scope 0 at $DIR/issue_41110.rs:+2:1: +2:2
|
|
return; // scope 0 at $DIR/issue_41110.rs:+2:2: +2:2
|
|
}
|
|
|
|
bb3 (cleanup): {
|
|
- drop(_3) -> [return: bb5, unwind terminate]; // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
|
|
+ goto -> bb5; // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
|
|
}
|
|
|
|
bb4 (cleanup): {
|
|
- drop(_4) -> [return: bb5, unwind terminate]; // scope 0 at $DIR/issue_41110.rs:+1:26: +1:27
|
|
+ goto -> bb5; // scope 0 at $DIR/issue_41110.rs:+1:26: +1:27
|
|
}
|
|
|
|
bb5 (cleanup): {
|
|
- drop(_2) -> [return: bb6, unwind terminate]; // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
|
|
+ goto -> bb8; // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
|
|
}
|
|
|
|
bb6 (cleanup): {
|
|
resume; // scope 0 at $DIR/issue_41110.rs:+0:1: +2:2
|
|
+ }
|
|
+
|
|
+ bb7 (cleanup): {
|
|
+ drop(_2) -> [return: bb6, unwind terminate]; // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
|
|
+ }
|
|
+
|
|
+ bb8 (cleanup): {
|
|
+ switchInt(_5) -> [0: bb6, otherwise: bb7]; // scope 0 at $DIR/issue_41110.rs:+1:27: +1:28
|
|
}
|
|
}
|
|
|