//@ 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!()
    }
}