rust/tests/mir-opt/issue_72181.main.built.after.mir

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

70 lines
1.5 KiB
Rust
Raw Normal View History

// MIR for `main` after built
fn main() -> () {
2023-06-06 13:47:00 +00:00
let mut _0: ();
let mut _1: usize;
let mut _3: Foo;
let mut _4: Foo;
let mut _5: u64;
let _6: usize;
let mut _7: usize;
let mut _8: bool;
scope 1 {
2023-06-06 13:47:00 +00:00
let _2: [Foo; 2];
scope 2 {
2023-06-06 13:47:00 +00:00
debug f => _2;
scope 3 {
}
}
}
bb0: {
2023-06-06 13:47:00 +00:00
StorageLive(_1);
_1 = std::mem::size_of::<Foo>() -> [return: bb1, unwind: bb5];
}
2020-10-02 20:11:24 +00:00
bb1: {
2023-06-06 13:47:00 +00:00
PlaceMention(_1);
StorageDead(_1);
StorageLive(_2);
StorageLive(_3);
_3 = Foo { a: const 42_u64 };
StorageLive(_4);
_4 = Foo { a: const 10_u64 };
_2 = [move _3, move _4];
StorageDead(_4);
StorageDead(_3);
FakeRead(ForLet(None), _2);
StorageLive(_5);
StorageLive(_6);
_6 = const 0_usize;
_7 = Len(_2);
_8 = Lt(copy _6, copy _7);
assert(move _8, "index out of bounds: the length is {} but the index is {}", move _7, copy _6) -> [success: bb3, unwind: bb5];
}
2020-10-02 20:11:24 +00:00
bb2: {
2024-02-12 03:56:03 +00:00
FakeRead(ForMatchedPlace(None), _1);
unreachable;
}
bb3: {
2023-06-06 13:47:00 +00:00
_5 = copy (_2[_6].0: u64);
PlaceMention(_5);
StorageDead(_6);
StorageDead(_5);
_0 = const ();
StorageDead(_2);
return;
}
bb4: {
2024-02-12 03:56:03 +00:00
FakeRead(ForMatchedPlace(None), _5);
unreachable;
}
bb5 (cleanup): {
2023-06-06 13:47:00 +00:00
resume;
}
}