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