From 8ee37932593c8bd7fad7cae605b2e0749ccd54b9 Mon Sep 17 00:00:00 2001 From: Louis Dureuil Date: Wed, 8 Jan 2025 13:58:14 +0100 Subject: [PATCH] Update after review --- .../milli/src/update/facet/new_incremental.rs | 30 +++++++++---------- .../src/update/index_documents/helpers/mod.rs | 4 +-- 2 files changed, 17 insertions(+), 17 deletions(-) diff --git a/crates/milli/src/update/facet/new_incremental.rs b/crates/milli/src/update/facet/new_incremental.rs index f132ebf19..fb2f3ae6b 100644 --- a/crates/milli/src/update/facet/new_incremental.rs +++ b/crates/milli/src/update/facet/new_incremental.rs @@ -66,7 +66,7 @@ impl FacetsUpdateIncremental { FacetFieldIdChange { facet_value: right, .. }| left.cmp(right), ); - self.inner.find_touched_parents( + self.inner.find_changed_parents( wtxn, 0, self.delta_data @@ -81,21 +81,21 @@ impl FacetsUpdateIncremental { } impl FacetsUpdateIncrementalInner { - /// WARNING: `touched_children` must be sorted in **reverse** lexicographic order. - fn find_touched_parents( + /// WARNING: `changed_children` must be sorted in **reverse** lexicographic order. + fn find_changed_parents( &self, wtxn: &mut RwTxn, child_level: u8, - mut touched_children: impl Iterator>, + mut changed_children: impl Iterator>, ) -> Result<()> { - let mut touched_parents = vec![]; + let mut changed_parents = vec![]; let Some(parent_level) = child_level.checked_add(1) else { return Ok(()) }; let parent_level_left_bound: FacetGroupKey<&[u8]> = FacetGroupKey { field_id: self.field_id, level: parent_level, left_bound: &[] }; let mut last_parent: Option> = None; - for child in &mut touched_children { + for child in &mut changed_children { if !valid_facet_value(&child) { continue; } @@ -132,7 +132,7 @@ impl FacetsUpdateIncrementalInner { last_parent = Some(parent_key.left_bound.to_owned()); // add to modified list for parent level - touched_parents.push(parent_key.left_bound.to_owned()); + changed_parents.push(parent_key.left_bound.to_owned()); self.compute_parent_group(wtxn, child_level, child)?; } Some(Err(err)) => return Err(err.into()), @@ -143,7 +143,7 @@ impl FacetsUpdateIncrementalInner { } } // do we have children without parents? - if let Some(child) = touched_children.next() { + if let Some(child) = changed_children.next() { // no parent for that key let mut it = self .db @@ -160,10 +160,10 @@ impl FacetsUpdateIncrementalInner { unsafe { it.del_current()? }; drop(it); // pop all elements and order to visit the new left bound - touched_parents.push(child.clone()); + changed_parents.push(child.clone()); self.compute_parent_group(wtxn, child_level, child)?; - for child in touched_children { - let new_left_bound = touched_parents.last_mut().unwrap(); + for child in changed_children { + let new_left_bound = changed_parents.last_mut().unwrap(); new_left_bound.clear(); new_left_bound.extend_from_slice(&child); self.compute_parent_group(wtxn, child_level, child)?; @@ -174,17 +174,17 @@ impl FacetsUpdateIncrementalInner { None => { drop(it); self.compute_parent_group(wtxn, child_level, child)?; - for child in touched_children { + for child in changed_children { self.compute_parent_group(wtxn, child_level, child)?; } } } } - if !touched_parents.is_empty() { - self.find_touched_parents( + if !changed_parents.is_empty() { + self.find_changed_parents( wtxn, parent_level, - touched_parents + changed_parents // no need to `rev` here because the parents were already visited in reverse order .into_iter(), )?; diff --git a/crates/milli/src/update/index_documents/helpers/mod.rs b/crates/milli/src/update/index_documents/helpers/mod.rs index 195d12455..236c63cc3 100644 --- a/crates/milli/src/update/index_documents/helpers/mod.rs +++ b/crates/milli/src/update/index_documents/helpers/mod.rs @@ -10,14 +10,14 @@ use fst::{IntoStreamer, Streamer}; pub use grenad_helpers::*; pub use merge_functions::*; -use crate::MAX_WORD_LENGTH; +use crate::{MAX_LMDB_KEY_LENGTH, MAX_WORD_LENGTH}; pub fn valid_lmdb_key(key: impl AsRef<[u8]>) -> bool { key.as_ref().len() <= MAX_WORD_LENGTH * 2 && !key.as_ref().is_empty() } pub fn valid_facet_value(facet_value: impl AsRef<[u8]>) -> bool { - facet_value.as_ref().len() <= (MAX_WORD_LENGTH * 2) - 3 && !facet_value.as_ref().is_empty() + facet_value.as_ref().len() <= MAX_LMDB_KEY_LENGTH - 3 && !facet_value.as_ref().is_empty() } /// Divides one slice into two at an index, returns `None` if mid is out of bounds.