rust/tests/mir-opt/box_expr.main.ElaborateDrop...

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

81 lines
4.0 KiB
Rust
Raw Normal View History

2020-04-03 05:09:01 +08:00
// MIR for `main` before ElaborateDrops
fn main() -> () {
2022-07-28 02:47:42 +08:00
let mut _0: (); // return place in scope 0 at $DIR/box_expr.rs:+0:11: +0:11
let _1: std::boxed::Box<S>; // in scope 0 at $DIR/box_expr.rs:+1:9: +1:10
let mut _2: usize; // in scope 0 at $DIR/box_expr.rs:+2:5: +2:23
let mut _3: usize; // in scope 0 at $DIR/box_expr.rs:+2:5: +2:23
let mut _4: *mut u8; // in scope 0 at $DIR/box_expr.rs:+2:5: +2:23
let mut _5: std::boxed::Box<S>; // in scope 0 at $DIR/box_expr.rs:+2:5: +2:23
let _6: (); // in scope 0 at $DIR/box_expr.rs:+3:5: +3:12
let mut _7: std::boxed::Box<S>; // in scope 0 at $DIR/box_expr.rs:+3:10: +3:11
2020-04-03 05:09:01 +08:00
scope 1 {
2022-07-28 02:47:42 +08:00
debug x => _1; // in scope 1 at $DIR/box_expr.rs:+1:9: +1:10
2020-04-03 05:09:01 +08:00
}
2021-09-17 06:04:02 +08:00
scope 2 {
}
2020-04-03 05:09:01 +08:00
bb0: {
2022-07-28 02:47:42 +08:00
StorageLive(_1); // scope 0 at $DIR/box_expr.rs:+1:9: +1:10
_2 = SizeOf(S); // scope 2 at $DIR/box_expr.rs:+2:5: +2:23
_3 = AlignOf(S); // scope 2 at $DIR/box_expr.rs:+2:5: +2:23
_4 = alloc::alloc::exchange_malloc(move _2, move _3) -> [return: bb1, unwind: bb9]; // scope 2 at $DIR/box_expr.rs:+2:5: +2:23
2020-04-03 05:09:01 +08:00
// mir::Constant
// + span: $DIR/box_expr.rs:8:5: 8:23
2022-07-06 22:14:46 +08:00
// + literal: Const { ty: unsafe fn(usize, usize) -> *mut u8 {alloc::alloc::exchange_malloc}, val: Value(<ZST>) }
2020-04-03 05:09:01 +08:00
}
2020-10-03 04:11:24 +08:00
bb1: {
StorageLive(_5); // scope 0 at $DIR/box_expr.rs:+2:5: +2:23
_5 = ShallowInitBox(move _4, S); // scope 0 at $DIR/box_expr.rs:+2:5: +2:23
(*_5) = S::new() -> [return: bb2, unwind: bb8]; // scope 0 at $DIR/box_expr.rs:+2:14: +2:22
2021-09-17 06:04:02 +08:00
// mir::Constant
// + span: $DIR/box_expr.rs:8:14: 8:20
2022-07-06 22:14:46 +08:00
// + literal: Const { ty: fn() -> S {S::new}, val: Value(<ZST>) }
}
bb2: {
_1 = move _5; // scope 0 at $DIR/box_expr.rs:+2:5: +2:23
drop(_5) -> [return: bb3, unwind: bb9]; // scope 0 at $DIR/box_expr.rs:+2:22: +2:23
2021-09-17 06:04:02 +08:00
}
bb3: {
StorageDead(_5); // scope 0 at $DIR/box_expr.rs:+2:22: +2:23
StorageLive(_6); // scope 1 at $DIR/box_expr.rs:+3:5: +3:12
StorageLive(_7); // scope 1 at $DIR/box_expr.rs:+3:10: +3:11
_7 = move _1; // scope 1 at $DIR/box_expr.rs:+3:10: +3:11
_6 = std::mem::drop::<Box<S>>(move _7) -> [return: bb4, unwind: bb6]; // scope 1 at $DIR/box_expr.rs:+3:5: +3:12
2020-04-03 05:09:01 +08:00
// mir::Constant
// + span: $DIR/box_expr.rs:9:5: 9:9
2022-07-06 22:14:46 +08:00
// + literal: Const { ty: fn(Box<S>) {std::mem::drop::<Box<S>>}, val: Value(<ZST>) }
2020-04-03 05:09:01 +08:00
}
2021-09-17 06:04:02 +08:00
bb4: {
StorageDead(_7); // scope 1 at $DIR/box_expr.rs:+3:11: +3:12
StorageDead(_6); // scope 1 at $DIR/box_expr.rs:+3:12: +3:13
_0 = const (); // scope 0 at $DIR/box_expr.rs:+0:11: +4:2
drop(_1) -> [return: bb5, unwind: bb9]; // scope 0 at $DIR/box_expr.rs:+4:1: +4:2
2020-10-03 04:11:24 +08:00
}
2021-09-17 06:04:02 +08:00
bb5: {
StorageDead(_1); // scope 0 at $DIR/box_expr.rs:+4:1: +4:2
return; // scope 0 at $DIR/box_expr.rs:+4:2: +4:2
2020-10-03 04:11:24 +08:00
}
bb6 (cleanup): {
2023-04-05 16:17:40 +08:00
drop(_7) -> [return: bb7, unwind terminate]; // scope 1 at $DIR/box_expr.rs:+3:11: +3:12
}
bb7 (cleanup): {
2023-04-05 16:17:40 +08:00
drop(_1) -> [return: bb9, unwind terminate]; // scope 0 at $DIR/box_expr.rs:+4:1: +4:2
}
bb8 (cleanup): {
2023-04-05 16:17:40 +08:00
drop(_5) -> [return: bb9, unwind terminate]; // scope 0 at $DIR/box_expr.rs:+2:22: +2:23
2021-09-17 06:04:02 +08:00
}
bb9 (cleanup): {
resume; // scope 0 at $DIR/box_expr.rs:+0:1: +4:2
2020-04-03 05:09:01 +08:00
}
}