-
Couldn't load subscription status.
- Fork 13.9k
Open
Labels
A-lintsArea: Lints (warnings about flaws in source code) such as unused_mut.Area: Lints (warnings about flaws in source code) such as unused_mut.A-patternsRelating to patterns and pattern matchingRelating to patterns and pattern matchingC-bugCategory: This is a bug.Category: This is a bug.E-needs-testCall for participation: An issue has been fixed and does not reproduce, but no test has been added.Call for participation: An issue has been fixed and does not reproduce, but no test has been added.L-false-positiveLint: False positive (should not have fired).Lint: False positive (should not have fired).L-unused_assignmentsLint: unused_assignmentsLint: unused_assignmentsT-compilerRelevant to the compiler team, which will review and decide on the PR/issue.Relevant to the compiler team, which will review and decide on the PR/issue.
Description
I tried this code (playground):
fn pnk(x: usize) -> &'static str { let mut k1 = "k1"; let mut h1 = "h1"; match x & 3 { 3 if { k1 = "unused?"; false } => (), _ if { h1 = k1; true } => (), _ => (), } h1 } fn main() { dbg!(pnk(3)); }I expected to see this happen: No lint complaints about the assignment to k1 in the first match guard being "unused", since the assignment is subsequently observed by the second match guard.
Instead, this happened: The unused_assignments lint has a false positive on the code above:
warning: value assigned to `k1` is never read --> src/main.rs:5:16 | 5 | 3 if { k1 = "unused?"; false } => (), | ^^ | = help: maybe it is overwritten before being read? = note: `#[warn(unused_assignments)]` on by default warning: `playground` (bin "playground") generated 1 warning Finished `dev` profile [unoptimized + debuginfo] target(s) in 0.89s Running `target/debug/playground` [src/main.rs:13:5] pnk(3) = "unused?" Meta
I'm testing on the playground, Rust stable 1.85.0
xFrednet
Metadata
Metadata
Assignees
Labels
A-lintsArea: Lints (warnings about flaws in source code) such as unused_mut.Area: Lints (warnings about flaws in source code) such as unused_mut.A-patternsRelating to patterns and pattern matchingRelating to patterns and pattern matchingC-bugCategory: This is a bug.Category: This is a bug.E-needs-testCall for participation: An issue has been fixed and does not reproduce, but no test has been added.Call for participation: An issue has been fixed and does not reproduce, but no test has been added.L-false-positiveLint: False positive (should not have fired).Lint: False positive (should not have fired).L-unused_assignmentsLint: unused_assignmentsLint: unused_assignmentsT-compilerRelevant to the compiler team, which will review and decide on the PR/issue.Relevant to the compiler team, which will review and decide on the PR/issue.