Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

When a match guard indirectly contains if let, rustc requires only the let_chains feature and not also if_let_guard #93150

Closed
ChayimFriedman2 opened this issue Jan 21, 2022 · 0 comments · Fixed by #93213
Labels
C-bug Category: This is a bug.

Comments

@ChayimFriedman2
Copy link
Contributor

If you compile the following code:

fn main() {
    match true {
        _ if let true = true => {}
        _ => {}
    }
}

rustc complains as expected:

error[E0658]: `if let` guards are experimental
 --> src/main.rs:3:11
  |
5 |         _ if let true = true => {}
  |           ^^^^^^^^^^^^^^^^^^
  |
  = note: see issue #51114 <https://github.com/rust-lang/rust/issues/51114> for more information
  = help: add `#![feature(if_let_guard)]` to the crate attributes to enable
  = help: you can write `if matches!(<expr>, <pattern>)` instead of `if let <pattern> = <expr>`

Playground.

However, if I use the let_chains feature, by e.g. wrapping the let true = true in parentheses, or adding another clause, it compiles without error:

#![feature(let_chains)]

fn main() {
    match true {
        _ if let true = true && true => {}
        _ => {}
    }
}

Playground.

It depends only on the let_chains feature, instead of both let_chains and if_let_guard.

This is because here:

if let ExprKind::Let(..) = cond.kind {
// Remove the last feature gating of a `let` expression since it's stable.
this.sess.gated_spans.ungate_last(sym::let_chains, cond.span);
let span = if_span.to(cond.span);
this.sess.gated_spans.gate(sym::if_let_guard, span);
}

We only gate it under if_let_guard if the let is directly under the guard node.

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
C-bug Category: This is a bug.
Projects
None yet
Development

Successfully merging a pull request may close this issue.

1 participant