No longer ignore the first child without parent

This commit is contained in:
Louis Dureuil 2025-01-08 16:25:30 +01:00
parent fd88c834c3
commit 6a577254fa
No known key found for this signature in database

View File

@ -91,16 +91,13 @@ impl FacetsUpdateIncrementalInner {
FacetGroupKey { field_id: self.field_id, level: parent_level, left_bound: &[] }; FacetGroupKey { field_id: self.field_id, level: parent_level, left_bound: &[] };
let mut last_parent: Option<Box<[u8]>> = None; let mut last_parent: Option<Box<[u8]>> = None;
let mut child_it = changed_children.drain(..); let mut child_it =
changed_children.drain(..).filter(|child| valid_facet_value(&child.facet_value));
'current_level: while let Some(child) = child_it.next() { 'current_level: while let Some(child) = child_it.next() {
if !valid_facet_value(&child.facet_value) {
continue;
}
if let Some(last_parent) = &last_parent { if let Some(last_parent) = &last_parent {
if &child.facet_value >= last_parent { if &child.facet_value >= last_parent {
self.compute_parent_group(wtxn, child_level, child.facet_value)?; self.compute_parent_group(wtxn, child_level, child.facet_value)?;
continue; continue 'current_level;
} }
} }
@ -136,10 +133,6 @@ impl FacetsUpdateIncrementalInner {
} }
Some(Err(err)) => return Err(err.into()), Some(Err(err)) => return Err(err.into()),
None => { None => {
self.compute_parent_group(wtxn, child_level, child.facet_value)?;
// do we have children without parents?
if let Some(child) = child_it.next() {
// no parent for that key // no parent for that key
let mut parent_it = self let mut parent_it = self
.db .db
@ -157,19 +150,14 @@ impl FacetsUpdateIncrementalInner {
// remove old left bound // remove old left bound
unsafe { parent_it.del_current()? }; unsafe { parent_it.del_current()? };
drop(parent_it); drop(parent_it);
// pop all elements and order to visit the new left bound
changed_parents.push(FacetFieldIdChange { changed_parents.push(FacetFieldIdChange {
facet_value: child.facet_value.clone(), facet_value: child.facet_value.clone(),
}); });
self.compute_parent_group( self.compute_parent_group(wtxn, child_level, child.facet_value)?;
wtxn, // pop all elements in order to visit the new left bound
child_level,
child.facet_value,
)?;
for child in child_it.by_ref() {
let new_left_bound = let new_left_bound =
&mut changed_parents.last_mut().unwrap().facet_value; &mut changed_parents.last_mut().unwrap().facet_value;
for child in child_it.by_ref() {
new_left_bound.clone_from(&child.facet_value); new_left_bound.clone_from(&child.facet_value);
self.compute_parent_group( self.compute_parent_group(
@ -185,11 +173,7 @@ impl FacetsUpdateIncrementalInner {
// 2. max level reached, exit // 2. max level reached, exit
None => { None => {
drop(parent_it); drop(parent_it);
self.compute_parent_group( self.compute_parent_group(wtxn, child_level, child.facet_value)?;
wtxn,
child_level,
child.facet_value,
)?;
for child in child_it.by_ref() { for child in child_it.by_ref() {
self.compute_parent_group( self.compute_parent_group(
wtxn, wtxn,
@ -203,7 +187,6 @@ impl FacetsUpdateIncrementalInner {
} }
} }
} }
}
if changed_parents.is_empty() { if changed_parents.is_empty() {
return Ok(()); return Ok(());
} }