Reuse ctor_sub_tys
when we have one around
This commit is contained in:
parent
d40f1b1172
commit
50b197c6ee
@ -83,8 +83,9 @@ fn specialize(
|
||||
(0..arity).map(|_| Self { patterns: Vec::new() }).collect();
|
||||
let relevant_patterns =
|
||||
self.patterns.iter().filter(|pat| ctor.is_covered_by(pcx, pat.ctor()));
|
||||
let ctor_sub_tys = pcx.ctor_sub_tys(ctor);
|
||||
for pat in relevant_patterns {
|
||||
let specialized = pat.specialize(pcx, ctor);
|
||||
let specialized = pat.specialize(pcx, ctor, ctor_sub_tys);
|
||||
for (subpat, column) in specialized.iter().zip(&mut specialized_columns) {
|
||||
if subpat.is_or_pat() {
|
||||
column.patterns.extend(subpat.flatten_or_pat())
|
||||
|
@ -81,10 +81,11 @@ pub(crate) fn specialize(
|
||||
&self,
|
||||
pcx: &PlaceCtxt<'_, 'p, Cx>,
|
||||
other_ctor: &Constructor<Cx>,
|
||||
ctor_sub_tys: &[Cx::Ty],
|
||||
) -> SmallVec<[&'p DeconstructedPat<'p, Cx>; 2]> {
|
||||
let wildcard_sub_tys = || {
|
||||
let tys = pcx.ctor_sub_tys(other_ctor);
|
||||
tys.iter()
|
||||
ctor_sub_tys
|
||||
.iter()
|
||||
.map(|ty| DeconstructedPat::wildcard(*ty))
|
||||
.map(|pat| pcx.mcx.wildcard_arena.alloc(pat) as &_)
|
||||
.collect()
|
||||
|
@ -874,11 +874,12 @@ fn pop_head_constructor(
|
||||
&self,
|
||||
pcx: &PlaceCtxt<'_, 'p, Cx>,
|
||||
ctor: &Constructor<Cx>,
|
||||
ctor_sub_tys: &[Cx::Ty],
|
||||
ctor_is_relevant: bool,
|
||||
) -> PatStack<'p, Cx> {
|
||||
// We pop the head pattern and push the new fields extracted from the arguments of
|
||||
// `self.head()`.
|
||||
let mut new_pats = self.head().specialize(pcx, ctor);
|
||||
let mut new_pats = self.head().specialize(pcx, ctor, ctor_sub_tys);
|
||||
new_pats.extend_from_slice(&self.pats[1..]);
|
||||
// `ctor` is relevant for this row if it is the actual constructor of this row, or if the
|
||||
// row has a wildcard and `ctor` is relevant for wildcards.
|
||||
@ -950,11 +951,12 @@ fn pop_head_constructor(
|
||||
&self,
|
||||
pcx: &PlaceCtxt<'_, 'p, Cx>,
|
||||
ctor: &Constructor<Cx>,
|
||||
ctor_sub_tys: &[Cx::Ty],
|
||||
ctor_is_relevant: bool,
|
||||
parent_row: usize,
|
||||
) -> MatrixRow<'p, Cx> {
|
||||
MatrixRow {
|
||||
pats: self.pats.pop_head_constructor(pcx, ctor, ctor_is_relevant),
|
||||
pats: self.pats.pop_head_constructor(pcx, ctor, ctor_sub_tys, ctor_is_relevant),
|
||||
parent_row,
|
||||
is_under_guard: self.is_under_guard,
|
||||
useful: false,
|
||||
@ -1079,7 +1081,8 @@ fn specialize_constructor(
|
||||
};
|
||||
for (i, row) in self.rows().enumerate() {
|
||||
if ctor.is_covered_by(pcx, row.head().ctor()) {
|
||||
let new_row = row.pop_head_constructor(pcx, ctor, ctor_is_relevant, i);
|
||||
let new_row =
|
||||
row.pop_head_constructor(pcx, ctor, ctor_sub_tys, ctor_is_relevant, i);
|
||||
matrix.expand_and_push(new_row);
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user