2016-11-29 15:10:26 +08:00
|
|
|
use self::Direction::{North, East, South, West};
|
|
|
|
|
2017-05-21 14:11:08 +03:00
|
|
|
#[derive(PartialEq, Eq)]
|
2016-11-29 15:10:26 +08:00
|
|
|
struct NewBool(bool);
|
|
|
|
|
2017-05-21 14:11:08 +03:00
|
|
|
#[derive(PartialEq, Eq)]
|
2016-11-29 15:10:26 +08:00
|
|
|
enum Direction {
|
|
|
|
North,
|
|
|
|
East,
|
|
|
|
South,
|
|
|
|
West
|
|
|
|
}
|
|
|
|
|
|
|
|
const TRUE_TRUE: (bool, bool) = (true, true);
|
|
|
|
|
|
|
|
fn nonexhaustive_1() {
|
|
|
|
match (true, false) {
|
|
|
|
//~^ ERROR non-exhaustive patterns: `(true, false)` not covered
|
|
|
|
TRUE_TRUE => (),
|
|
|
|
(false, false) => (),
|
|
|
|
(false, true) => ()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const NONE: Option<Direction> = None;
|
|
|
|
const EAST: Direction = East;
|
|
|
|
|
|
|
|
fn nonexhaustive_2() {
|
|
|
|
match Some(Some(North)) {
|
2022-09-03 03:01:35 +00:00
|
|
|
//~^ ERROR non-exhaustive patterns: `Some(Some(Direction::West))` not covered
|
2016-11-29 15:10:26 +08:00
|
|
|
Some(NONE) => (),
|
|
|
|
Some(Some(North)) => (),
|
|
|
|
Some(Some(EAST)) => (),
|
|
|
|
Some(Some(South)) => (),
|
|
|
|
None => ()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const NEW_FALSE: NewBool = NewBool(false);
|
|
|
|
struct Foo {
|
|
|
|
bar: Option<Direction>,
|
|
|
|
baz: NewBool
|
|
|
|
}
|
|
|
|
|
|
|
|
const STATIC_FOO: Foo = Foo { bar: None, baz: NEW_FALSE };
|
|
|
|
|
|
|
|
fn nonexhaustive_3() {
|
|
|
|
match (Foo { bar: Some(North), baz: NewBool(true) }) {
|
2022-09-03 03:01:35 +00:00
|
|
|
//~^ ERROR non-exhaustive patterns: `Foo { bar: Some(Direction::North), baz: NewBool(true) }`
|
2016-11-29 15:10:26 +08:00
|
|
|
Foo { bar: None, baz: NewBool(true) } => (),
|
|
|
|
Foo { bar: _, baz: NEW_FALSE } => (),
|
|
|
|
Foo { bar: Some(West), baz: NewBool(true) } => (),
|
|
|
|
Foo { bar: Some(South), .. } => (),
|
|
|
|
Foo { bar: Some(EAST), .. } => ()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
nonexhaustive_1();
|
|
|
|
nonexhaustive_2();
|
|
|
|
nonexhaustive_3();
|
|
|
|
}
|