]> git.lizzy.rs Git - rust.git/blob - src/test/mir-opt/lower_slice_len.bound.LowerSliceLenCalls.diff
Auto merge of #98553 - the8472:next_chunk_opt, r=Mark-Simulacrum
[rust.git] / src / test / mir-opt / lower_slice_len.bound.LowerSliceLenCalls.diff
1 - // MIR for `bound` before LowerSliceLenCalls
2 + // MIR for `bound` after LowerSliceLenCalls
3   
4   fn bound(_1: usize, _2: &[u8]) -> u8 {
5       debug index => _1;                   // in scope 0 at $DIR/lower_slice_len.rs:4:14: 4:19
6       debug slice => _2;                   // in scope 0 at $DIR/lower_slice_len.rs:4:28: 4:33
7       let mut _0: u8;                      // return place in scope 0 at $DIR/lower_slice_len.rs:4:45: 4:47
8       let mut _3: bool;                    // in scope 0 at $DIR/lower_slice_len.rs:5:8: 5:27
9       let mut _4: usize;                   // in scope 0 at $DIR/lower_slice_len.rs:5:8: 5:13
10       let mut _5: usize;                   // in scope 0 at $DIR/lower_slice_len.rs:5:16: 5:27
11       let mut _6: &[u8];                   // in scope 0 at $DIR/lower_slice_len.rs:5:16: 5:27
12       let _7: usize;                       // in scope 0 at $DIR/lower_slice_len.rs:6:15: 6:20
13       let mut _8: usize;                   // in scope 0 at $DIR/lower_slice_len.rs:6:9: 6:21
14       let mut _9: bool;                    // in scope 0 at $DIR/lower_slice_len.rs:6:9: 6:21
15   
16       bb0: {
17           StorageLive(_3);                 // scope 0 at $DIR/lower_slice_len.rs:5:8: 5:27
18           StorageLive(_4);                 // scope 0 at $DIR/lower_slice_len.rs:5:8: 5:13
19           _4 = _1;                         // scope 0 at $DIR/lower_slice_len.rs:5:8: 5:13
20           StorageLive(_5);                 // scope 0 at $DIR/lower_slice_len.rs:5:16: 5:27
21           StorageLive(_6);                 // scope 0 at $DIR/lower_slice_len.rs:5:16: 5:27
22           _6 = &(*_2);                     // scope 0 at $DIR/lower_slice_len.rs:5:16: 5:27
23 -         _5 = core::slice::<impl [u8]>::len(move _6) -> bb1; // scope 0 at $DIR/lower_slice_len.rs:5:16: 5:27
24 -                                          // mir::Constant
25 -                                          // + span: $DIR/lower_slice_len.rs:5:22: 5:25
26 -                                          // + literal: Const { ty: for<'r> fn(&'r [u8]) -> usize {core::slice::<impl [u8]>::len}, val: Value(<ZST>) }
27 +         _5 = Len((*_6));                 // scope 0 at $DIR/lower_slice_len.rs:5:16: 5:27
28 +         goto -> bb1;                     // scope 0 at $DIR/lower_slice_len.rs:5:16: 5:27
29       }
30   
31       bb1: {
32           StorageDead(_6);                 // scope 0 at $DIR/lower_slice_len.rs:5:26: 5:27
33           _3 = Lt(move _4, move _5);       // scope 0 at $DIR/lower_slice_len.rs:5:8: 5:27
34           StorageDead(_5);                 // scope 0 at $DIR/lower_slice_len.rs:5:26: 5:27
35           StorageDead(_4);                 // scope 0 at $DIR/lower_slice_len.rs:5:26: 5:27
36           switchInt(move _3) -> [false: bb4, otherwise: bb2]; // scope 0 at $DIR/lower_slice_len.rs:5:8: 5:27
37       }
38   
39       bb2: {
40           StorageLive(_7);                 // scope 0 at $DIR/lower_slice_len.rs:6:15: 6:20
41           _7 = _1;                         // scope 0 at $DIR/lower_slice_len.rs:6:15: 6:20
42           _8 = Len((*_2));                 // scope 0 at $DIR/lower_slice_len.rs:6:9: 6:21
43           _9 = Lt(_7, _8);                 // scope 0 at $DIR/lower_slice_len.rs:6:9: 6:21
44           assert(move _9, "index out of bounds: the length is {} but the index is {}", move _8, _7) -> bb3; // scope 0 at $DIR/lower_slice_len.rs:6:9: 6:21
45       }
46   
47       bb3: {
48           _0 = (*_2)[_7];                  // scope 0 at $DIR/lower_slice_len.rs:6:9: 6:21
49           StorageDead(_7);                 // scope 0 at $DIR/lower_slice_len.rs:7:5: 7:6
50           goto -> bb5;                     // scope 0 at $DIR/lower_slice_len.rs:5:5: 9:6
51       }
52   
53       bb4: {
54           _0 = const 42_u8;                // scope 0 at $DIR/lower_slice_len.rs:8:9: 8:11
55           goto -> bb5;                     // scope 0 at $DIR/lower_slice_len.rs:5:5: 9:6
56       }
57   
58       bb5: {
59           StorageDead(_3);                 // scope 0 at $DIR/lower_slice_len.rs:9:5: 9:6
60           return;                          // scope 0 at $DIR/lower_slice_len.rs:10:2: 10:2
61       }
62   }
63