26cb6c7287
mark `min_exhaustive_patterns` as complete This is step 1 and 2 of my [proposal](https://github.com/rust-lang/rust/issues/119612#issuecomment-1918097361) to move `min_exhaustive_patterns` forward. The vast majority of in-tree use cases of `exhaustive_patterns` are covered by `min_exhaustive_patterns`. There are a few cases that still require `exhaustive_patterns` in tests and they're all behind references. r? ``@ghost``
40 lines
985 B
Rust
40 lines
985 B
Rust
//@ revisions: min_exhaustive_patterns exhaustive_patterns
|
|
#![cfg_attr(exhaustive_patterns, feature(exhaustive_patterns))]
|
|
#![cfg_attr(min_exhaustive_patterns, feature(min_exhaustive_patterns))]
|
|
#![feature(never_type)]
|
|
|
|
mod foo {
|
|
pub struct SecretlyEmpty {
|
|
_priv: !,
|
|
}
|
|
|
|
pub struct NotSoSecretlyEmpty {
|
|
pub _pub: !,
|
|
}
|
|
}
|
|
|
|
struct NotSoSecretlyEmpty {
|
|
_priv: !,
|
|
}
|
|
|
|
enum Foo {
|
|
//~^ NOTE `Foo` defined here
|
|
A(foo::SecretlyEmpty),
|
|
//~^ NOTE not covered
|
|
B(foo::NotSoSecretlyEmpty),
|
|
C(NotSoSecretlyEmpty),
|
|
D(u32, u32),
|
|
}
|
|
|
|
fn main() {
|
|
let x: Foo = Foo::D(123, 456);
|
|
let Foo::D(_y, _z) = x;
|
|
//~^ ERROR refutable pattern in local binding
|
|
//~| `Foo::A(_)` not covered
|
|
//~| NOTE `let` bindings require an "irrefutable pattern"
|
|
//~| NOTE for more information
|
|
//~| NOTE pattern `Foo::A(_)` is currently uninhabited
|
|
//~| NOTE the matched value is of type `Foo`
|
|
//~| HELP you might want to use `let else`
|
|
}
|