summary refs log tree commit diff
path: root/src/test/mir-opt/issues/issue_59352.num_to_digit.PreCodegen.after.mir
blob: 19d161ac2b1039c3f7f1bce445ba602de1d53e10 (plain)
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
// MIR for `num_to_digit` after PreCodegen

fn num_to_digit(_1: char) -> u32 {
    debug num => _1;                     // in scope 0 at $DIR/issue-59352.rs:12:21: 12:24
    let mut _0: u32;                     // return place in scope 0 at $DIR/issue-59352.rs:12:35: 12:38
    let mut _2: char;                    // in scope 0 at $DIR/issue-59352.rs:14:8: 14:11
    let mut _3: std::option::Option<u32>; // in scope 0 at $DIR/issue-59352.rs:14:26: 14:41
    let mut _4: char;                    // in scope 0 at $DIR/issue-59352.rs:14:26: 14:29
    let mut _5: u32;                     // in scope 0 at $DIR/issue-59352.rs:14:8: 14:23
    let mut _11: isize;                  // in scope 0 at $DIR/issue-59352.rs:14:8: 14:23
    scope 1 (inlined char::methods::<impl char>::is_digit) { // at $DIR/issue-59352.rs:14:8: 14:23
        debug self => _2;                // in scope 1 at $DIR/issue-59352.rs:14:8: 14:23
        debug radix => _5;               // in scope 1 at $DIR/issue-59352.rs:14:8: 14:23
        let mut _6: &std::option::Option<u32>; // in scope 1 at $DIR/issue-59352.rs:14:8: 14:23
        let _7: std::option::Option<u32>; // in scope 1 at $DIR/issue-59352.rs:14:8: 14:23
        let mut _8: char;                // in scope 1 at $DIR/issue-59352.rs:14:8: 14:23
        scope 2 (inlined Option::<u32>::is_some) { // at $DIR/issue-59352.rs:14:8: 14:23
            debug self => _6;            // in scope 2 at $DIR/issue-59352.rs:14:8: 14:23
            let mut _9: isize;           // in scope 2 at $DIR/issue-59352.rs:14:8: 14:23
        }
    }
    scope 3 (inlined #[track_caller] Option::<u32>::unwrap) { // at $DIR/issue-59352.rs:14:26: 14:50
        debug self => _3;                // in scope 3 at $DIR/issue-59352.rs:14:26: 14:50
        let mut _10: isize;              // in scope 3 at $DIR/issue-59352.rs:14:26: 14:50
        scope 4 {
            debug val => _0;             // in scope 4 at $DIR/issue-59352.rs:14:26: 14:50
        }
    }

    bb0: {
        StorageLive(_2);                 // scope 0 at $DIR/issue-59352.rs:14:8: 14:11
        _2 = _1;                         // scope 0 at $DIR/issue-59352.rs:14:8: 14:11
        StorageLive(_5);                 // scope 0 at $DIR/issue-59352.rs:14:8: 14:23
        _5 = const 8_u32;                // scope 0 at $DIR/issue-59352.rs:14:8: 14:23
        StorageLive(_6);                 // scope 1 at $DIR/issue-59352.rs:14:8: 14:23
        StorageLive(_7);                 // scope 1 at $DIR/issue-59352.rs:14:8: 14:23
        StorageLive(_8);                 // scope 1 at $DIR/issue-59352.rs:14:8: 14:23
        _8 = _2;                         // scope 1 at $DIR/issue-59352.rs:14:8: 14:23
        _7 = char::methods::<impl char>::to_digit(move _8, const 8_u32) -> bb5; // scope 1 at $DIR/issue-59352.rs:14:8: 14:23
                                         // mir::Constant
                                         // + span: $DIR/issue-59352.rs:14:8: 14:23
                                         // + literal: Const { ty: fn(char, u32) -> std::option::Option<u32> {std::char::methods::<impl char>::to_digit}, val: Value(Scalar(<ZST>)) }
    }

    bb1: {
        StorageDead(_11);                // scope 0 at $DIR/issue-59352.rs:14:5: 14:63
        StorageLive(_3);                 // scope 0 at $DIR/issue-59352.rs:14:26: 14:41
        StorageLive(_4);                 // scope 0 at $DIR/issue-59352.rs:14:26: 14:29
        _4 = _1;                         // scope 0 at $DIR/issue-59352.rs:14:26: 14:29
        _3 = char::methods::<impl char>::to_digit(move _4, const 8_u32) -> bb3; // scope 0 at $DIR/issue-59352.rs:14:26: 14:41
                                         // mir::Constant
                                         // + span: $DIR/issue-59352.rs:14:30: 14:38
                                         // + literal: Const { ty: fn(char, u32) -> std::option::Option<u32> {std::char::methods::<impl char>::to_digit}, val: Value(Scalar(<ZST>)) }
    }

    bb2: {
        StorageDead(_11);                // scope 0 at $DIR/issue-59352.rs:14:5: 14:63
        _0 = const 0_u32;                // scope 0 at $DIR/issue-59352.rs:14:60: 14:61
        goto -> bb4;                     // scope 0 at $DIR/issue-59352.rs:14:5: 14:63
    }

    bb3: {
        StorageDead(_4);                 // scope 0 at $DIR/issue-59352.rs:14:40: 14:41
        StorageLive(_10);                // scope 0 at $DIR/issue-59352.rs:14:26: 14:50
        _10 = discriminant(_3);          // scope 3 at $DIR/issue-59352.rs:14:26: 14:50
        switchInt(move _10) -> [0_isize: bb6, 1_isize: bb8, otherwise: bb7]; // scope 3 at $DIR/issue-59352.rs:14:26: 14:50
    }

    bb4: {
        return;                          // scope 0 at $DIR/issue-59352.rs:15:2: 15:2
    }

    bb5: {
        _6 = &_7;                        // scope 1 at $DIR/issue-59352.rs:14:8: 14:23
        StorageDead(_8);                 // scope 1 at $DIR/issue-59352.rs:14:8: 14:23
        StorageLive(_9);                 // scope 1 at $DIR/issue-59352.rs:14:8: 14:23
        _9 = discriminant((*_6));        // scope 2 at $DIR/issue-59352.rs:14:8: 14:23
        StorageLive(_11);                // scope 2 at $DIR/issue-59352.rs:14:8: 14:23
        _11 = move _9;                   // scope 2 at $DIR/issue-59352.rs:14:8: 14:23
        StorageDead(_9);                 // scope 1 at $DIR/issue-59352.rs:14:8: 14:23
        StorageDead(_6);                 // scope 1 at $DIR/issue-59352.rs:14:8: 14:23
        StorageDead(_7);                 // scope 1 at $DIR/issue-59352.rs:14:8: 14:23
        StorageDead(_5);                 // scope 0 at $DIR/issue-59352.rs:14:8: 14:23
        StorageDead(_2);                 // scope 0 at $DIR/issue-59352.rs:14:22: 14:23
        switchInt(move _11) -> [1_isize: bb1, otherwise: bb2]; // scope 0 at $DIR/issue-59352.rs:14:5: 14:63
    }

    bb6: {
        core::panicking::panic(const "called `Option::unwrap()` on a `None` value"); // scope 3 at $DIR/issue-59352.rs:14:26: 14:50
                                         // mir::Constant
                                         // + span: $DIR/issue-59352.rs:14:26: 14:50
                                         // + literal: Const { ty: fn(&'static str) -> ! {core::panicking::panic}, val: Value(Scalar(<ZST>)) }
                                         // ty::Const
                                         // + ty: &str
                                         // + val: Value(Slice { data: Allocation { bytes: [99, 97, 108, 108, 101, 100, 32, 96, 79, 112, 116, 105, 111, 110, 58, 58, 117, 110, 119, 114, 97, 112, 40, 41, 96, 32, 111, 110, 32, 97, 32, 96, 78, 111, 110, 101, 96, 32, 118, 97, 108, 117, 101], relocations: Relocations(SortedMap { data: [] }), init_mask: InitMask { blocks: [8796093022207], len: Size { raw: 43 } }, size: Size { raw: 43 }, align: Align { pow2: 0 }, mutability: Not, extra: () }, start: 0, end: 43 })
                                         // mir::Constant
                                         // + span: $DIR/issue-59352.rs:14:26: 14:50
                                         // + literal: Const { ty: &str, val: Value(Slice { data: Allocation { bytes: [99, 97, 108, 108, 101, 100, 32, 96, 79, 112, 116, 105, 111, 110, 58, 58, 117, 110, 119, 114, 97, 112, 40, 41, 96, 32, 111, 110, 32, 97, 32, 96, 78, 111, 110, 101, 96, 32, 118, 97, 108, 117, 101], relocations: Relocations(SortedMap { data: [] }), init_mask: InitMask { blocks: [8796093022207], len: Size { raw: 43 } }, size: Size { raw: 43 }, align: Align { pow2: 0 }, mutability: Not, extra: () }, start: 0, end: 43 }) }
    }

    bb7: {
        unreachable;                     // scope 3 at $DIR/issue-59352.rs:14:26: 14:50
    }

    bb8: {
        _0 = move ((_3 as Some).0: u32); // scope 3 at $DIR/issue-59352.rs:14:26: 14:50
        StorageDead(_10);                // scope 0 at $DIR/issue-59352.rs:14:26: 14:50
        StorageDead(_3);                 // scope 0 at $DIR/issue-59352.rs:14:49: 14:50
        goto -> bb4;                     // scope 0 at $DIR/issue-59352.rs:14:5: 14:63
    }
}