2019-12-22 02:43:13 +00:00
|
|
|
use std::mem::zeroed;
|
2017-01-25 06:48:20 +00:00
|
|
|
enum Void {}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let x: Result<u32, &'static Void> = Ok(23);
|
|
|
|
let _ = match x { //~ ERROR non-exhaustive
|
|
|
|
Ok(n) => n,
|
|
|
|
};
|
|
|
|
|
2019-12-22 02:43:13 +00:00
|
|
|
// This is pretty much instant UB. However, we have no choice -- we need to
|
|
|
|
// test matching on a reference to `&Void`; we cannot do anything other than
|
|
|
|
// just accept the fact that this is UB if `main` did run, but it doesn't;
|
|
|
|
// this test only checks that these are feature-gated.
|
|
|
|
let x: &Void = unsafe { zeroed() };
|
2017-02-23 20:46:19 +00:00
|
|
|
let _ = match x {}; //~ ERROR non-exhaustive
|
2017-01-25 06:48:20 +00:00
|
|
|
|
2019-12-22 02:43:13 +00:00
|
|
|
let x: (Void,) = unsafe { zeroed() };
|
2017-02-23 20:46:19 +00:00
|
|
|
let _ = match x {}; //~ ERROR non-exhaustive
|
2017-01-25 06:48:20 +00:00
|
|
|
|
2019-12-22 02:43:13 +00:00
|
|
|
let x: [Void; 1] = unsafe { zeroed() };
|
2017-02-23 20:46:19 +00:00
|
|
|
let _ = match x {}; //~ ERROR non-exhaustive
|
2017-01-25 06:48:20 +00:00
|
|
|
|
2019-12-22 02:43:13 +00:00
|
|
|
let x: &[Void] = unsafe { zeroed() };
|
2017-01-25 06:48:20 +00:00
|
|
|
let _ = match x { //~ ERROR non-exhaustive
|
|
|
|
&[] => (),
|
|
|
|
};
|
|
|
|
|
2019-12-22 02:43:13 +00:00
|
|
|
let x: Void = unsafe { zeroed() };
|
2017-01-25 06:48:20 +00:00
|
|
|
let _ = match x {}; // okay
|
|
|
|
|
|
|
|
let x: Result<u32, Void> = Ok(23);
|
|
|
|
let _ = match x { //~ ERROR non-exhaustive
|
|
|
|
Ok(x) => x,
|
|
|
|
};
|
|
|
|
|
|
|
|
let x: Result<u32, Void> = Ok(23);
|
|
|
|
let Ok(x) = x;
|
|
|
|
//~^ ERROR refutable
|
|
|
|
}
|