File: issue_106141.outer.Inline.panic-unwind.diff

package info (click to toggle)
rustc 1.85.0%2Bdfsg3-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental, sid, trixie
  • size: 893,396 kB
  • sloc: xml: 158,127; python: 35,830; javascript: 19,497; cpp: 19,002; sh: 17,245; ansic: 13,127; asm: 4,376; makefile: 1,051; perl: 29; lisp: 29; ruby: 19; sql: 11
file content (49 lines) | stat: -rw-r--r-- 1,190 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
- // MIR for `outer` before Inline
+ // MIR for `outer` after Inline
  
  fn outer() -> usize {
      let mut _0: usize;
+     scope 1 (inlined inner) {
+         let mut _1: &[bool; 1];
+         let mut _2: bool;
+         let mut _3: bool;
+         scope 2 {
+             debug buffer => _1;
+             scope 3 {
+                 debug index => _0;
+             }
+         }
+     }
  
      bb0: {
-         _0 = inner() -> [return: bb1, unwind continue];
+         StorageLive(_1);
+         StorageLive(_2);
+         _1 = const inner::promoted[0];
+         _0 = index() -> [return: bb1, unwind continue];
      }
  
      bb1: {
+         StorageLive(_3);
+         _2 = Lt(copy _0, const 1_usize);
+         assert(move _2, "index out of bounds: the length is {} but the index is {}", const 1_usize, copy _0) -> [success: bb2, unwind continue];
+     }
+ 
+     bb2: {
+         _3 = copy (*_1)[_0];
+         switchInt(move _3) -> [0: bb3, otherwise: bb4];
+     }
+ 
+     bb3: {
+         _0 = const 0_usize;
+         goto -> bb4;
+     }
+ 
+     bb4: {
+         StorageDead(_3);
+         StorageDead(_2);
+         StorageDead(_1);
          return;
      }
  }