summaryrefslogtreecommitdiffstats
path: root/tests/ui/structs-enums/enum-nullable-simplifycfg-misopt.rs
blob: a05cf8b93d5bd215787ad88cf96fc36b933ca8ec (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
// run-pass

/*!
 * This is a regression test for a bug in LLVM, fixed in upstream r179587,
 * where the switch instructions generated for destructuring enums
 * represented with nullable pointers could be misoptimized in some cases.
 */

enum List<X> { Nil, Cons(X, #[allow(unused_tuple_struct_fields)] Box<List<X>>) }
pub fn main() {
    match List::Cons(10, Box::new(List::Nil)) {
        List::Cons(10, _) => {}
        List::Nil => {}
        _ => panic!()
    }
}