File: slice_iter.slice_iter_generic_is_empty.PreCodegen.after.panic-unwind.mir

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 (76 lines) | stat: -rw-r--r-- 2,293 bytes parent folder | download | duplicates (4)
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
// MIR for `slice_iter_generic_is_empty` after PreCodegen

fn slice_iter_generic_is_empty(_1: &std::slice::Iter<'_, T>) -> bool {
    debug it => _1;
    let mut _0: bool;
    scope 1 (inlined <std::slice::Iter<'_, T> as ExactSizeIterator>::is_empty) {
        let mut _2: *const *const T;
        let mut _3: *const std::ptr::NonNull<T>;
        let mut _8: *const T;
        scope 2 {
            let _4: std::ptr::NonNull<T>;
            let _9: usize;
            scope 3 {
            }
            scope 4 {
                scope 8 (inlined <NonNull<T> as PartialEq>::eq) {
                    let mut _5: std::ptr::NonNull<T>;
                    let mut _6: *mut T;
                    let mut _7: *mut T;
                    scope 9 (inlined NonNull::<T>::as_ptr) {
                    }
                    scope 10 (inlined NonNull::<T>::as_ptr) {
                    }
                }
            }
            scope 5 (inlined std::ptr::const_ptr::<impl *const T>::addr) {
                scope 6 (inlined std::ptr::const_ptr::<impl *const T>::cast::<()>) {
                }
            }
            scope 7 (inlined std::ptr::const_ptr::<impl *const *const T>::cast::<NonNull<T>>) {
            }
        }
    }

    bb0: {
        StorageLive(_9);
        StorageLive(_8);
        StorageLive(_4);
        switchInt(const <T as std::mem::SizedTypeProperties>::IS_ZST) -> [0: bb1, otherwise: bb2];
    }

    bb1: {
        StorageLive(_3);
        StorageLive(_2);
        _2 = &raw const ((*_1).1: *const T);
        _3 = copy _2 as *const std::ptr::NonNull<T> (PtrToPtr);
        StorageDead(_2);
        _4 = copy (*_3);
        StorageDead(_3);
        StorageLive(_6);
        StorageLive(_5);
        _5 = copy ((*_1).0: std::ptr::NonNull<T>);
        _6 = copy _5 as *mut T (Transmute);
        StorageDead(_5);
        StorageLive(_7);
        _7 = copy _4 as *mut T (Transmute);
        _0 = Eq(move _6, move _7);
        StorageDead(_7);
        StorageDead(_6);
        goto -> bb3;
    }

    bb2: {
        _8 = copy ((*_1).1: *const T);
        _9 = copy _8 as usize (Transmute);
        _0 = Eq(copy _9, const 0_usize);
        goto -> bb3;
    }

    bb3: {
        StorageDead(_4);
        StorageDead(_8);
        StorageDead(_9);
        return;
    }
}