rust/tests/mir-opt/dataflow-const-prop/inherit_overflow.main.DataflowConstProp.panic-unwind.diff

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

46 lines
1.2 KiB
Diff
Raw Normal View History

- // MIR for `main` before DataflowConstProp
+ // MIR for `main` after DataflowConstProp
fn main() -> () {
2023-06-06 09:47:00 -04:00
let mut _0: ();
let mut _1: u8;
let mut _2: u8;
let mut _3: u8;
scope 1 {
}
2023-06-06 09:47:00 -04:00
scope 2 (inlined <u8 as Add>::add) {
debug self => _2;
debug other => _3;
let mut _4: (u8, bool);
}
bb0: {
2023-06-06 09:47:00 -04:00
StorageLive(_1);
StorageLive(_2);
_2 = const u8::MAX;
StorageLive(_3);
_3 = const 1_u8;
2023-10-04 17:50:03 +00:00
StorageLive(_4);
2023-06-06 09:47:00 -04:00
- _4 = CheckedAdd(_2, _3);
2023-06-23 17:53:09 +01:00
- assert(!move (_4.1: bool), "attempt to compute `{} + {}`, which would overflow", _2, _3) -> [success: bb1, unwind continue];
2023-09-17 09:35:06 +00:00
+ _4 = const (0_u8, true);
2023-06-23 17:53:09 +01:00
+ assert(!const true, "attempt to compute `{} + {}`, which would overflow", const u8::MAX, const 1_u8) -> [success: bb1, unwind continue];
}
bb1: {
2023-06-06 09:47:00 -04:00
- _1 = move (_4.0: u8);
+ _1 = const 0_u8;
2023-10-04 17:50:03 +00:00
StorageDead(_4);
2023-06-06 09:47:00 -04:00
StorageDead(_3);
StorageDead(_2);
StorageDead(_1);
_0 = const ();
return;
}
2023-09-17 09:35:06 +00:00
+ }
+
+ ALLOC0 (size: 2, align: 1) {
+ 00 01 │ ..
}