]> git.lizzy.rs Git - rust.git/blob - tests/mir-opt/lower_array_len.array_bound_mut.NormalizeArrayLen.diff
Rollup merge of #107769 - compiler-errors:pointer-like, r=eholk
[rust.git] / tests / mir-opt / lower_array_len.array_bound_mut.NormalizeArrayLen.diff
1 - // MIR for `array_bound_mut` before NormalizeArrayLen
2 + // MIR for `array_bound_mut` after NormalizeArrayLen
3   
4   fn array_bound_mut(_1: usize, _2: &mut [u8; N]) -> u8 {
5       debug index => _1;                   // in scope 0 at $DIR/lower_array_len.rs:+0:40: +0:45
6       debug slice => _2;                   // in scope 0 at $DIR/lower_array_len.rs:+0:54: +0:59
7       let mut _0: u8;                      // return place in scope 0 at $DIR/lower_array_len.rs:+0:78: +0:80
8       let mut _3: bool;                    // in scope 0 at $DIR/lower_array_len.rs:+1:8: +1:27
9       let mut _4: usize;                   // in scope 0 at $DIR/lower_array_len.rs:+1:8: +1:13
10       let mut _5: usize;                   // in scope 0 at $DIR/lower_array_len.rs:+1:16: +1:27
11       let mut _6: &[u8];                   // in scope 0 at $DIR/lower_array_len.rs:+1:16: +1:27
12       let mut _7: &[u8; N];                // in scope 0 at $DIR/lower_array_len.rs:+1:16: +1:27
13       let _8: usize;                       // in scope 0 at $DIR/lower_array_len.rs:+2:15: +2:20
14       let mut _9: usize;                   // in scope 0 at $DIR/lower_array_len.rs:+2:9: +2:21
15       let mut _10: bool;                   // in scope 0 at $DIR/lower_array_len.rs:+2:9: +2:21
16       let _11: usize;                      // in scope 0 at $DIR/lower_array_len.rs:+4:15: +4:16
17       let mut _12: usize;                  // in scope 0 at $DIR/lower_array_len.rs:+4:9: +4:17
18       let mut _13: bool;                   // in scope 0 at $DIR/lower_array_len.rs:+4:9: +4:17
19   
20       bb0: {
21           StorageLive(_3);                 // scope 0 at $DIR/lower_array_len.rs:+1:8: +1:27
22           StorageLive(_4);                 // scope 0 at $DIR/lower_array_len.rs:+1:8: +1:13
23           _4 = _1;                         // scope 0 at $DIR/lower_array_len.rs:+1:8: +1:13
24           StorageLive(_5);                 // scope 0 at $DIR/lower_array_len.rs:+1:16: +1:27
25           StorageLive(_6);                 // scope 0 at $DIR/lower_array_len.rs:+1:16: +1:27
26           StorageLive(_7);                 // scope 0 at $DIR/lower_array_len.rs:+1:16: +1:27
27           _7 = &(*_2);                     // scope 0 at $DIR/lower_array_len.rs:+1:16: +1:27
28           _6 = move _7 as &[u8] (Pointer(Unsize)); // scope 0 at $DIR/lower_array_len.rs:+1:16: +1:27
29           StorageDead(_7);                 // scope 0 at $DIR/lower_array_len.rs:+1:20: +1:21
30 -         _5 = Len((*_6));                 // scope 0 at $DIR/lower_array_len.rs:+1:16: +1:27
31 +         _5 = const N;                    // scope 0 at $DIR/lower_array_len.rs:+1:16: +1:27
32           goto -> bb1;                     // scope 0 at $DIR/lower_array_len.rs:+1:16: +1:27
33       }
34   
35       bb1: {
36           StorageDead(_6);                 // scope 0 at $DIR/lower_array_len.rs:+1:26: +1:27
37           _3 = Lt(move _4, move _5);       // scope 0 at $DIR/lower_array_len.rs:+1:8: +1:27
38           StorageDead(_5);                 // scope 0 at $DIR/lower_array_len.rs:+1:26: +1:27
39           StorageDead(_4);                 // scope 0 at $DIR/lower_array_len.rs:+1:26: +1:27
40           switchInt(move _3) -> [0: bb4, otherwise: bb2]; // scope 0 at $DIR/lower_array_len.rs:+1:8: +1:27
41       }
42   
43       bb2: {
44           StorageLive(_8);                 // scope 0 at $DIR/lower_array_len.rs:+2:15: +2:20
45           _8 = _1;                         // scope 0 at $DIR/lower_array_len.rs:+2:15: +2:20
46           _9 = Len((*_2));                 // scope 0 at $DIR/lower_array_len.rs:+2:9: +2:21
47           _10 = Lt(_8, _9);                // scope 0 at $DIR/lower_array_len.rs:+2:9: +2:21
48           assert(move _10, "index out of bounds: the length is {} but the index is {}", move _9, _8) -> bb3; // scope 0 at $DIR/lower_array_len.rs:+2:9: +2:21
49       }
50   
51       bb3: {
52           _0 = (*_2)[_8];                  // scope 0 at $DIR/lower_array_len.rs:+2:9: +2:21
53           StorageDead(_8);                 // scope 0 at $DIR/lower_array_len.rs:+3:5: +3:6
54           goto -> bb6;                     // scope 0 at $DIR/lower_array_len.rs:+1:5: +7:6
55       }
56   
57       bb4: {
58           StorageLive(_11);                // scope 0 at $DIR/lower_array_len.rs:+4:15: +4:16
59           _11 = const 0_usize;             // scope 0 at $DIR/lower_array_len.rs:+4:15: +4:16
60           _12 = Len((*_2));                // scope 0 at $DIR/lower_array_len.rs:+4:9: +4:17
61           _13 = Lt(_11, _12);              // scope 0 at $DIR/lower_array_len.rs:+4:9: +4:17
62           assert(move _13, "index out of bounds: the length is {} but the index is {}", move _12, _11) -> bb5; // scope 0 at $DIR/lower_array_len.rs:+4:9: +4:17
63       }
64   
65       bb5: {
66           (*_2)[_11] = const 42_u8;        // scope 0 at $DIR/lower_array_len.rs:+4:9: +4:22
67           StorageDead(_11);                // scope 0 at $DIR/lower_array_len.rs:+4:22: +4:23
68           _0 = const 42_u8;                // scope 0 at $DIR/lower_array_len.rs:+6:9: +6:11
69           goto -> bb6;                     // scope 0 at $DIR/lower_array_len.rs:+1:5: +7:6
70       }
71   
72       bb6: {
73           StorageDead(_3);                 // scope 0 at $DIR/lower_array_len.rs:+7:5: +7:6
74           return;                          // scope 0 at $DIR/lower_array_len.rs:+8:2: +8:2
75       }
76   }
77