mirror of
https://github.com/rust-lang/rust.git
synced 2025-04-29 11:37:39 +00:00

When we recover from a pattern parse error, or a pattern uses `..`, we keep track of that and affect resolution error for missing bindings that could have been provided by that pattern. We differentiate between `..` and parse recovery. We silence resolution errors likely caused by the pattern parse error. ``` error[E0425]: cannot find value `title` in this scope --> $DIR/struct-pattern-with-missing-fields-resolve-error.rs:19:30 | LL | println!("[{}]({})", title, url); | ^^^^^ not found in this scope | note: `Website` has a field `title` which could have been included in this pattern, but it wasn't --> $DIR/struct-pattern-with-missing-fields-resolve-error.rs:17:12 | LL | / struct Website { LL | | url: String, LL | | title: Option<String> , | | ----- defined here LL | | } | |_- ... LL | if let Website { url, .. } = website { | ^^^^^^^^^^^^^^^^^^^ this pattern doesn't include `title`, which is available in `Website` ``` Fix #74863.
23 lines
709 B
Rust
23 lines
709 B
Rust
struct Website {
|
|
url: String,
|
|
title: Option<String> ,//~ NOTE defined here
|
|
}
|
|
|
|
fn main() {
|
|
let website = Website {
|
|
url: "http://www.example.com".into(),
|
|
title: Some("Example Domain".into()),
|
|
};
|
|
|
|
if let Website { url, Some(title) } = website { //~ ERROR expected `,`
|
|
//~^ NOTE while parsing the fields for this pattern
|
|
println!("[{}]({})", title, url); // we hide the errors for `title` and `url`
|
|
}
|
|
|
|
if let Website { url, .. } = website { //~ NOTE `Website` has a field `title`
|
|
//~^ NOTE this pattern
|
|
println!("[{}]({})", title, url); //~ ERROR cannot find value `title` in this scope
|
|
//~^ NOTE not found in this scope
|
|
}
|
|
}
|