From dc0db358abe19481e475e10c32149b53370f1a1c Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Thu, 30 May 2024 05:57:31 +0200 Subject: Merging upstream version 1.72.1+dfsg1. Signed-off-by: Daniel Baumann --- ...expr.main.ElaborateDrops.before.panic-abort.mir | 71 ++++++++++++++++++++++ 1 file changed, 71 insertions(+) create mode 100644 tests/mir-opt/box_expr.main.ElaborateDrops.before.panic-abort.mir (limited to 'tests/mir-opt/box_expr.main.ElaborateDrops.before.panic-abort.mir') diff --git a/tests/mir-opt/box_expr.main.ElaborateDrops.before.panic-abort.mir b/tests/mir-opt/box_expr.main.ElaborateDrops.before.panic-abort.mir new file mode 100644 index 000000000..d196b045a --- /dev/null +++ b/tests/mir-opt/box_expr.main.ElaborateDrops.before.panic-abort.mir @@ -0,0 +1,71 @@ +// MIR for `main` before ElaborateDrops + +fn main() -> () { + let mut _0: (); + let _1: std::boxed::Box; + let mut _2: usize; + let mut _3: usize; + let mut _4: *mut u8; + let mut _5: std::boxed::Box; + let _6: (); + let mut _7: std::boxed::Box; + scope 1 { + debug x => _1; + } + scope 2 { + } + + bb0: { + StorageLive(_1); + _2 = SizeOf(S); + _3 = AlignOf(S); + _4 = alloc::alloc::exchange_malloc(move _2, move _3) -> [return: bb1, unwind: bb9]; + } + + bb1: { + StorageLive(_5); + _5 = ShallowInitBox(move _4, S); + (*_5) = S::new() -> [return: bb2, unwind: bb8]; + } + + bb2: { + _1 = move _5; + drop(_5) -> [return: bb3, unwind: bb9]; + } + + bb3: { + StorageDead(_5); + StorageLive(_6); + StorageLive(_7); + _7 = move _1; + _6 = std::mem::drop::>(move _7) -> [return: bb4, unwind: bb6]; + } + + bb4: { + StorageDead(_7); + StorageDead(_6); + _0 = const (); + drop(_1) -> [return: bb5, unwind: bb9]; + } + + bb5: { + StorageDead(_1); + return; + } + + bb6 (cleanup): { + drop(_7) -> [return: bb7, unwind terminate]; + } + + bb7 (cleanup): { + drop(_1) -> [return: bb9, unwind terminate]; + } + + bb8 (cleanup): { + drop(_5) -> [return: bb9, unwind terminate]; + } + + bb9 (cleanup): { + resume; + } +} -- cgit v1.2.3