2018-08-08 07:28:26 -05:00
|
|
|
error[E0004]: non-exhaustive patterns: `(true, false)` not covered
|
2020-03-31 20:10:13 -05:00
|
|
|
--> $DIR/match-arm-statics-2.rs:17:11
|
2018-08-08 07:28:26 -05:00
|
|
|
|
|
|
|
|
LL | match (true, false) {
|
|
|
|
| ^^^^^^^^^^^^^ pattern `(true, false)` not covered
|
Point at enum definition when match patterns are not exhaustive
```
error[E0004]: non-exhaustive patterns: type `X` is non-empty
--> file.rs:9:11
|
1 | / enum X {
2 | | A,
| | - variant not covered
3 | | B,
| | - variant not covered
4 | | C,
| | - variant not covered
5 | | }
| |_- `X` defined here
...
9 | match x {
| ^
|
= help: ensure that all possible cases are being handled, possibly by adding wildcards or more match arms
error[E0004]: non-exhaustive patterns: `B` and `C` not covered
--> file.rs:11:11
|
1 | / enum X {
2 | | A,
3 | | B,
4 | | C,
| | - not covered
5 | | }
| |_- `X` defined here
...
11 | match x {
| ^ patterns `C` not covered
```
When a match expression doesn't have patterns covering every variant,
point at the enum's definition span. On a best effort basis, point at the
variant(s) that are missing. This does not handle the case when the missing
pattern is due to a field's enum variants:
```
enum E1 {
A,
B,
C,
}
enum E2 {
A(E1),
B,
}
fn foo() {
match E2::A(E1::A) {
E2::A(E1::B) => {}
E2::B => {}
}
//~^ ERROR `E2::A(E1::A)` and `E2::A(E1::C)` not handled
}
```
Unify look between match with no arms and match with some missing patterns.
Fix #37518.
2019-02-10 07:12:00 -06:00
|
|
|
|
|
2020-03-27 00:44:30 -05:00
|
|
|
= note: the matched value is of type `(bool, bool)`
|
2021-12-16 16:46:13 -06:00
|
|
|
help: ensure that all possible cases are being handled by adding a match arm with a wildcard pattern or an explicit pattern as shown
|
2021-12-15 20:28:09 -06:00
|
|
|
|
|
|
|
|
LL ~ (false, true) => (),
|
|
|
|
LL + (true, false) => todo!()
|
|
|
|
|
|
2018-08-08 07:28:26 -05:00
|
|
|
|
2022-09-02 22:01:35 -05:00
|
|
|
error[E0004]: non-exhaustive patterns: `Some(Some(Direction::West))` not covered
|
2020-03-31 20:10:13 -05:00
|
|
|
--> $DIR/match-arm-statics-2.rs:29:11
|
2018-08-08 07:28:26 -05:00
|
|
|
|
|
|
|
|
LL | match Some(Some(North)) {
|
2022-09-02 22:01:35 -05:00
|
|
|
| ^^^^^^^^^^^^^^^^^ pattern `Some(Some(Direction::West))` not covered
|
2021-06-10 06:52:00 -05:00
|
|
|
|
|
2021-12-15 23:06:44 -06:00
|
|
|
note: `Option<Option<Direction>>` defined here
|
|
|
|
--> $SRC_DIR/core/src/option.rs:LL:COL
|
2022-12-12 09:25:04 -06:00
|
|
|
::: $SRC_DIR/core/src/option.rs:LL:COL
|
|
|
|
|
|
|
|
|
= note: not covered
|
|
|
|
|
|
|
|
|
= note: not covered
|
2020-09-02 02:40:56 -05:00
|
|
|
= note: the matched value is of type `Option<Option<Direction>>`
|
2021-12-16 16:46:13 -06:00
|
|
|
help: ensure that all possible cases are being handled by adding a match arm with a wildcard pattern or an explicit pattern as shown
|
2021-12-15 20:28:09 -06:00
|
|
|
|
|
|
|
|
LL ~ None => (),
|
2022-09-02 22:01:35 -05:00
|
|
|
LL + Some(Some(Direction::West)) => todo!()
|
2021-12-15 20:28:09 -06:00
|
|
|
|
|
2018-08-08 07:28:26 -05:00
|
|
|
|
2022-09-02 22:01:35 -05:00
|
|
|
error[E0004]: non-exhaustive patterns: `Foo { bar: Some(Direction::North), baz: NewBool(true) }` not covered
|
2020-03-31 20:10:13 -05:00
|
|
|
--> $DIR/match-arm-statics-2.rs:48:11
|
2018-08-08 07:28:26 -05:00
|
|
|
|
|
2021-12-15 23:06:44 -06:00
|
|
|
LL | match (Foo { bar: Some(North), baz: NewBool(true) }) {
|
2022-09-02 22:01:35 -05:00
|
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ pattern `Foo { bar: Some(Direction::North), baz: NewBool(true) }` not covered
|
2021-12-15 23:06:44 -06:00
|
|
|
|
|
|
|
|
note: `Foo` defined here
|
|
|
|
--> $DIR/match-arm-statics-2.rs:40:8
|
Point at enum definition when match patterns are not exhaustive
```
error[E0004]: non-exhaustive patterns: type `X` is non-empty
--> file.rs:9:11
|
1 | / enum X {
2 | | A,
| | - variant not covered
3 | | B,
| | - variant not covered
4 | | C,
| | - variant not covered
5 | | }
| |_- `X` defined here
...
9 | match x {
| ^
|
= help: ensure that all possible cases are being handled, possibly by adding wildcards or more match arms
error[E0004]: non-exhaustive patterns: `B` and `C` not covered
--> file.rs:11:11
|
1 | / enum X {
2 | | A,
3 | | B,
4 | | C,
| | - not covered
5 | | }
| |_- `X` defined here
...
11 | match x {
| ^ patterns `C` not covered
```
When a match expression doesn't have patterns covering every variant,
point at the enum's definition span. On a best effort basis, point at the
variant(s) that are missing. This does not handle the case when the missing
pattern is due to a field's enum variants:
```
enum E1 {
A,
B,
C,
}
enum E2 {
A(E1),
B,
}
fn foo() {
match E2::A(E1::A) {
E2::A(E1::B) => {}
E2::B => {}
}
//~^ ERROR `E2::A(E1::A)` and `E2::A(E1::C)` not handled
}
```
Unify look between match with no arms and match with some missing patterns.
Fix #37518.
2019-02-10 07:12:00 -06:00
|
|
|
|
|
2021-12-15 23:06:44 -06:00
|
|
|
LL | struct Foo {
|
|
|
|
| ^^^
|
2020-03-27 00:44:30 -05:00
|
|
|
= note: the matched value is of type `Foo`
|
2021-12-16 16:46:13 -06:00
|
|
|
help: ensure that all possible cases are being handled by adding a match arm with a wildcard pattern or an explicit pattern as shown
|
2021-12-15 20:28:09 -06:00
|
|
|
|
|
|
|
|
LL ~ Foo { bar: Some(EAST), .. } => (),
|
2022-09-02 22:01:35 -05:00
|
|
|
LL + Foo { bar: Some(Direction::North), baz: NewBool(true) } => todo!()
|
2021-12-15 20:28:09 -06:00
|
|
|
|
|
2018-08-08 07:28:26 -05:00
|
|
|
|
|
|
|
error: aborting due to 3 previous errors
|
|
|
|
|
|
|
|
For more information about this error, try `rustc --explain E0004`.
|