2023-10-13 00:20:06 +02:00
error[E0004]: non-exhaustive patterns: `usize::MAX..` not covered
2020-10-24 19:21:40 -04:00
--> $DIR/feature-gate-precise_pointer_size_matching.rs:2:11
2018-11-30 00:44:33 +00:00
|
2019-03-09 15:03:44 +03:00
LL | match 0usize {
2023-10-13 00:20:06 +02:00
| ^^^^^^ pattern `usize::MAX..` 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 05:12:00 -08:00
|
2020-03-27 06:44:30 +01:00
= note: the matched value is of type `usize`
2023-10-13 00:20:06 +02:00
= note: `usize` does not have a fixed maximum value, so half-open ranges are necessary to match exhaustively
2021-12-16 22:46:13 +00: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-16 02:14:17 +00:00
|
2023-02-27 17:43:39 +00:00
LL ~ 0..=usize::MAX => {},
2023-10-13 00:20:06 +02:00
LL + usize::MAX.. => todo!()
2021-12-16 02:14:17 +00:00
|
2018-11-30 00:44:33 +00:00
2023-10-13 00:20:06 +02:00
error[E0004]: non-exhaustive patterns: `..isize::MIN` and `isize::MAX..` not covered
2020-10-24 19:21:40 -04:00
--> $DIR/feature-gate-precise_pointer_size_matching.rs:10:11
2018-11-30 00:44:33 +00:00
|
2019-03-09 15:03:44 +03:00
LL | match 0isize {
2023-10-13 00:20:06 +02:00
| ^^^^^^ patterns `..isize::MIN` and `isize::MAX..` 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 05:12:00 -08:00
|
2020-03-27 06:44:30 +01:00
= note: the matched value is of type `isize`
2023-10-13 00:20:06 +02:00
= note: `isize` does not have fixed minimum and maximum values, so half-open ranges are necessary to match exhaustively
help: ensure that all possible cases are being handled by adding a match arm with a wildcard pattern, a match arm with multiple or-patterns as shown, or multiple match arms
2021-12-16 02:14:17 +00:00
|
2023-02-27 17:43:39 +00:00
LL ~ isize::MIN..=isize::MAX => {},
2023-10-13 00:20:06 +02:00
LL + ..isize::MIN | isize::MAX.. => todo!()
2021-12-16 02:14:17 +00:00
|
2018-11-30 00:44:33 +00:00
error: aborting due to 2 previous errors
For more information about this error, try `rustc --explain E0004`.