File: unwrap_unchecked.unwrap_unchecked.Inline.panic-unwind.diff

package info (click to toggle)
rustc-web 1.78.0%2Bdfsg1-2~deb11u3
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 1,245,360 kB
  • sloc: xml: 147,985; javascript: 18,022; sh: 11,083; python: 10,265; ansic: 6,172; cpp: 5,023; asm: 4,390; makefile: 4,269
file content (57 lines) | stat: -rw-r--r-- 1,465 bytes parent folder | download
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
50
51
52
53
54
55
56
57
- // MIR for `unwrap_unchecked` before Inline
+ // MIR for `unwrap_unchecked` after Inline
  
  fn unwrap_unchecked(_1: Option<T>) -> T {
      debug slf => _1;
      let mut _0: T;
      let mut _2: std::option::Option<T>;
+     scope 1 (inlined #[track_caller] Option::<T>::unwrap_unchecked) {
+         debug self => _2;
+         let mut _3: isize;
+         scope 2 {
+             debug val => _0;
+         }
+         scope 3 {
+             scope 4 (inlined unreachable_unchecked) {
+                 let mut _4: bool;
+                 let _5: ();
+                 scope 5 {
+                 }
+             }
+         }
+     }
  
      bb0: {
          StorageLive(_2);
          _2 = move _1;
-         _0 = Option::<T>::unwrap_unchecked(move _2) -> [return: bb1, unwind: bb2];
+         StorageLive(_3);
+         StorageLive(_5);
+         _3 = discriminant(_2);
+         switchInt(move _3) -> [0: bb2, 1: bb3, otherwise: bb1];
      }
  
      bb1: {
-         StorageDead(_2);
-         return;
+         unreachable;
      }
  
-     bb2 (cleanup): {
-         resume;
+     bb2: {
+         StorageLive(_4);
+         _4 = UbCheck(LanguageUb);
+         assume(_4);
+         _5 = unreachable_unchecked::precondition_check() -> [return: bb1, unwind unreachable];
+     }
+ 
+     bb3: {
+         _0 = move ((_2 as Some).0: T);
+         StorageDead(_5);
+         StorageDead(_3);
+         StorageDead(_2);
+         return;
      }
  }