check_match: Dereference ref x before comparing it and some other type
The arity of `ref x` is always 1, so it needs to be dereferenced before being compared with some other type whose arity is not 1. Fixes #23009.
This commit is contained in:
parent
766a4e1acc
commit
edbc0e509f
2 changed files with 31 additions and 1 deletions
|
|
@ -646,6 +646,7 @@ fn is_useful(cx: &MatchCheckCtxt,
|
|||
if rows[0].len() == 0 {
|
||||
return NotUseful;
|
||||
}
|
||||
assert!(rows.iter().all(|r| r.len() == v.len()));
|
||||
let real_pat = match rows.iter().find(|r| (*r)[0].id != DUMMY_NODE_ID) {
|
||||
Some(r) => raw_pat(r[0]),
|
||||
None if v.len() == 0 => return NotUseful,
|
||||
|
|
@ -654,7 +655,12 @@ fn is_useful(cx: &MatchCheckCtxt,
|
|||
let left_ty = if real_pat.id == DUMMY_NODE_ID {
|
||||
ty::mk_nil(cx.tcx)
|
||||
} else {
|
||||
ty::pat_ty(cx.tcx, &*real_pat)
|
||||
let left_ty = ty::pat_ty(cx.tcx, &*real_pat);
|
||||
|
||||
match real_pat.node {
|
||||
ast::PatIdent(ast::BindByRef(..), _, _) => ty::deref(left_ty, false).unwrap().ty,
|
||||
_ => left_ty,
|
||||
}
|
||||
};
|
||||
|
||||
let max_slice_length = rows.iter().filter_map(|row| match row[0].node {
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue