fix: check orpat in missing match

This commit is contained in:
bvanjoi 2023-01-14 18:51:49 +08:00
parent 32be158630
commit e9724e55df

View file

@ -269,6 +269,7 @@ fn does_pat_match_variant(pat: &Pat, var: &Pat) -> bool {
(Pat::TuplePat(tpat), Pat::TuplePat(tvar)) => {
tpat.fields().zip(tvar.fields()).all(|(p, v)| does_pat_match_variant(&p, &v))
}
(Pat::OrPat(opat), _) => opat.pats().any(|p| does_pat_match_variant(&p, var)),
_ => utils::does_pat_match_variant(pat, var),
}
}
@ -525,6 +526,19 @@ fn foo(a: bool) {
add_missing_match_arms,
r#"
fn foo(a: bool) {
match (a, a)$0 {
(true | false, true) => {}
(true, false) => {}
(false, false) => {}
}
}
"#,
);
check_assist_not_applicable(
add_missing_match_arms,
r#"
fn foo(a: bool) {
match (a, a)$0 {
(true, true) => {}
(true, false) => {}
@ -565,6 +579,26 @@ fn foo(a: bool) {
add_missing_match_arms,
r#"
fn foo(a: bool) {
match (a, a)$0 {
(true | false, true) => {}
}
}
"#,
r#"
fn foo(a: bool) {
match (a, a) {
(true | false, true) => {}
$0(true, false) => todo!(),
(false, false) => todo!(),
}
}
"#,
);
check_assist(
add_missing_match_arms,
r#"
fn foo(a: bool) {
match (a, a)$0 {
(false, true) => {}
}
@ -882,6 +916,33 @@ fn main() {
}
"#,
);
check_assist(
add_missing_match_arms,
r#"
enum E { A, B, C }
fn main() {
use E::*;
match (A, B, C)$0 {
(A | B , A, A | B | C) => (),
(A | B | C , B | C, A | B | C) => (),
}
}
"#,
r#"
enum E { A, B, C }
fn main() {
use E::*;
match (A, B, C) {
(A | B , A, A | B | C) => (),
(A | B | C , B | C, A | B | C) => (),
$0(C, A, A) => todo!(),
(C, A, B) => todo!(),
(C, A, C) => todo!(),
}
}
"#,
)
}
#[test]