blob: be8e00fa1bbedfa448fa4e2f8c3ec45c1948cc3a (
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(dead_code)] Box<List<X>>) }
pub fn main() {
    match List::Cons(10, Box::new(List::Nil)) {
        List::Cons(10, _) => {}
        List::Nil => {}
        _ => panic!()
    }
}
 |