-
Notifications
You must be signed in to change notification settings - Fork 13k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
unreachable_patterns
lint due to min_exhaustive_patterns
#129031
Comments
@Nadrieril: Do you mind preparing a PR to split out these new cases from the |
This is a great point IMO, and feels like enough justification to warrant splitting this lint out. |
@rustbot labels +T-lang +I-lang-nominated Nominating to handle the question of whether bumping the lint to |
Yep, will prepare a PR when I get a moment |
These warnings currently on nightly will be unresolvable until Rust 1.82 is released, or <rust-lang/rust#129031> is fixed in some other way. After Rust 1.82, we can simply delete these match arms (and in fact replace the `match`es with `let`s, if we wish).
Can we make sure this is part of a group, so that macros that intentionally TBH my instinct here is that people should be allowing it on the arm specifically, rather than globally, if they feel the need. (Or the latest-rust CI can allow it while the MSRV-rust CI can still deny the warning.) |
FWIW, I don't think we should treat the introduction of |
@rustbot labels -I-lang-nominated We discussed this in our triage meeting today. We didn't feel that separating out this lint was necessary because, among other reasons, the We also discussed how this could be a good use case for |
I think this is overstated, because doing that also gives a naming lint (because the constant is And in some cases you get specific deny-by-default lints like error[E0170]: pattern binding `Less` is named the same as one of the variants of the type `std::cmp::Ordering`
--> src/lib.rs:3:9
|
3 | Less => {},
| ^^^^ help: to match on the variant, qualify the path: `std::cmp::Ordering::Less`
|
= note: `#[deny(bindings_with_variant_name)]` on by default So if you can find a heuristic that we can make a new deny-by-default lint against "gee, that sure looks like you meant to match a constant there" for, please propose it. I love approving "hey, we know that case and it's not what you wanted" lints :) |
I still think that this should be split. Just because users can put an |
I find the unreachable patterns lint to be very high signal towards there being an underlying problem with the code, and impossible patterns to be useful for signaling "hey, this code is dead" but not necessarily at the same severity level as the former, especially because we required users to include these dead arms previously. I find it kind of a shame to lump these two together in the mean time, as users churn to remove these arms now that pattern exhaustiveness takes never into account, but a lint group is fine I guess. |
I'm also in favor of delaying the lint. The ability to omit the arms is the heart of the feature, we can add the lint later for discoverability. |
I have a PR up: #129103 |
Our feeling, among those on the call, was that we do want this lint to fire, and that this is the purpose of lints, even though, yes, we're unfortunately going from requiring it to warning about it. Given that, and that we today discussed and discarded the idea of doing this over an edition, I doubt we're going to have appetite for that. Could we perhaps make this lint machine-applicable in some targeted way (i.e. that would distinguish these no-op cases from cases that might indicate a bug)? I known that doesn't address the MSRV thing, but it would make the migration easier otherwise. |
The proposed |
Could we ad a note to the lint message along the lines of "if you need this match arm for compatibility with older Rust, add |
Renominating this based on seeing feedback about impact. |
I think that an MSRV flag for this would be ideal because even this is just a subset of impossible patterns, and presumably more will be added in the future. I don't think that being forced to separate the lint into a different name every time a new case gets added is a good idea, but I would accept as a reasonable compromise changing what is implicitly allowed by the lint with an MSRV flag. |
I would love to have the --msrv flag for this and many other purposes, but that's going to take a while to 1) add, 2) stabilize, and 3) wire into Cargo to pass automatically. We need at least an interim mitigation for users of stable 1.82. |
I'm not at all pleased that the lang team thinks it's okay to add a deny-by-default lint in Clippy where following its instructions breaks compatibility with, not my older MSRV, but _the previous compiler version._ Why the compiler can't accept the old 'match x {}' uninhabited type test, I don't know. This appears to be the right fix for now. Upstream bug: rust-lang/rust#129031
I mean, truthfully, I think that the simplest immediate mitigation is to not trigger this lint for impossible patterns. This allows omitting them but won't complain if you include them. Once a better mitigation is in place (like an MSRV-aware linter) that can be fixed. I don't think that separating out impossible patterns as its own lint category is a good idea, since like I said, that pattern will be extended in the future to include more patterns than are noticed right now. |
I think that mitigation would be ok, but I suspect that distinguishing the cases that shouldn't trigger here is about the same amount of work as creating a new lint for those cases. It's less work downstream though if there's nothing you need to |
New factor to take into account: in some (rare) cases, because of type inference the arm cannot in fact be removed in edition 2021: #129352 |
@clarfonthey wrote:
That's a really good point. We have the goal of eventually removing those branches, but I think our original decision about linting here was based on not having the possibility of MSRV-aware linting in the future, so we wouldn't have been able to do any better. Given the possibility of @Nadrieril wrte:
...this, I think we should revert this decision and avoid linting on this for now. |
I have a PR ready if y'all want to FCP this in time for the beta fork (August 30th, tho we can of course always backport). EDIT: I can't count, that's too short. Still, PR is there and we can discuss details. |
This link seems to point to this issue. Did you mean #129103? |
whoops, indeed 🙏 |
I think if we get consensus and we're in FCP, we can reasonably get this merged in before the deadline even though we don't have a full 10 days until then. |
Another factor:
(don't mind the fact that this could be written differently, the real code this is derived from does need the match) This emits the unreachable pattern warning... on Windows targets only. |
Another case:
The "right" fix here would be to add |
…ble, r=compiler-errors Don't warn empty branches unreachable for now The [stabilization](rust-lang#122792) of `min_exhaustive_patterns` updated the `unreachable_pattern` lint to trigger on empty arms too. This has caused some amount of churn, and imposes an unjoyful `#[allow(unreachable_patterns)]` onto library authors who want to stay backwards-compatible. While I think the lint should eventually cover these cases, for transition's sake I'd prefer to revert linting to what it was prior to stabilization, at least for now. Fixes rust-lang#129031. r? `@compiler-errors`
and 32-bits targets. |
…ble, r=compiler-errors Don't warn empty branches unreachable for now The [stabilization](rust-lang#122792) of `min_exhaustive_patterns` updated the `unreachable_pattern` lint to trigger on empty arms too. This has caused some amount of churn, and imposes an unjoyful `#[allow(unreachable_patterns)]` onto library authors who want to stay backwards-compatible. While I think the lint should eventually cover these cases, for transition's sake I'd prefer to revert linting to what it was prior to stabilization, at least for now. Fixes rust-lang#129031. r? `@compiler-errors`
Rollup merge of rust-lang#129103 - Nadrieril:dont-warn-empty-unreachable, r=compiler-errors Don't warn empty branches unreachable for now The [stabilization](rust-lang#122792) of `min_exhaustive_patterns` updated the `unreachable_pattern` lint to trigger on empty arms too. This has caused some amount of churn, and imposes an unjoyful `#[allow(unreachable_patterns)]` onto library authors who want to stay backwards-compatible. While I think the lint should eventually cover these cases, for transition's sake I'd prefer to revert linting to what it was prior to stabilization, at least for now. Fixes rust-lang#129031. r? ``@compiler-errors``
This is more fallout from rust-lang/rust#129031 -- the lang team appears to have relented, but removing this lint hasn't been backported into Beta yet. So we're in a situation where traditional matches for uninhabited types are fine on both stable and nightly, but failing on beta. Not sure what to do except disable beta.
Code
Current output
Desired output
Until the 2024 edition, or the code's MSRV is ≥ 1.82, no warning.
Rationale and extra context
Deleting the
Err(e) => match e {}
arm will produce code which does not warn on nightly/1.82, but which does not compile on 1.80. This means that users which wish to keep a warning-free-ish nightly (or beta, eventually) build will have to#[allow(unreachable_patterns)]
from now until 1.82 is released, or perhaps even until their next MSRV increase.Deferring the warning until an edition or explicit MSRV increase seems to me to be a good way to avoid churn in the form of
#[allow]
s. Such#[allow]
s are particularly dangerous becauseunreachable_patterns
is also the lint that detects binding patterns that were intended to be matching against constants instead, so declaring it on a wide scope might hide serious bugs, especially if (as is likely) they're not promptly removed upon the release of 1.82.Rust Version
Anything else?
I noticed this due to my CI against nightly, but comments on the stabilization PR #122792 (comment) mentioned it first. I'm filing this issue to make sure it is not overlooked by being only visible in that comment thread.
The text was updated successfully, but these errors were encountered: