mirror of
https://github.com/meilisearch/meilisearch.git
synced 2025-10-23 20:16:29 +00:00
Reduce formatting time
This commit is contained in:
@@ -897,6 +897,14 @@ fn format_fields<'a>(
|
|||||||
let mut matches_position = compute_matches.then(BTreeMap::new);
|
let mut matches_position = compute_matches.then(BTreeMap::new);
|
||||||
let mut document = document.clone();
|
let mut document = document.clone();
|
||||||
|
|
||||||
|
// reduce the formated option list to the attributes that should be formatted,
|
||||||
|
// instead of all the attribute to display.
|
||||||
|
let formating_fields_options: Vec<_> = formatted_options
|
||||||
|
.iter()
|
||||||
|
.filter(|(_, option)| option.should_format())
|
||||||
|
.map(|(fid, option)| (field_ids_map.name(*fid).unwrap(), option))
|
||||||
|
.collect();
|
||||||
|
|
||||||
// select the attributes to retrieve
|
// select the attributes to retrieve
|
||||||
let displayable_names =
|
let displayable_names =
|
||||||
displayable_ids.iter().map(|&fid| field_ids_map.name(fid).expect("Missing field name"));
|
displayable_ids.iter().map(|&fid| field_ids_map.name(fid).expect("Missing field name"));
|
||||||
@@ -905,13 +913,15 @@ fn format_fields<'a>(
|
|||||||
// to the value and merge them together. eg. If a user said he wanted to highlight `doggo`
|
// to the value and merge them together. eg. If a user said he wanted to highlight `doggo`
|
||||||
// and crop `doggo.name`. `doggo.name` needs to be highlighted + cropped while `doggo.age` is only
|
// and crop `doggo.name`. `doggo.name` needs to be highlighted + cropped while `doggo.age` is only
|
||||||
// highlighted.
|
// highlighted.
|
||||||
let format = formatted_options
|
// Warn: The time to compute the `format` list scales with the number of field to format;
|
||||||
|
// cummulated with `map_leaf_values` that iterates over all the nested fields, it gives a quadratic complexity:
|
||||||
|
// `d*f` where `d` is the total number of field to display and `f` the total number of field to format.
|
||||||
|
let format = formating_fields_options
|
||||||
.iter()
|
.iter()
|
||||||
.filter(|(field, _option)| {
|
.filter(|(name, _option)| {
|
||||||
let name = field_ids_map.name(**field).unwrap();
|
|
||||||
milli::is_faceted_by(name, key) || milli::is_faceted_by(key, name)
|
milli::is_faceted_by(name, key) || milli::is_faceted_by(key, name)
|
||||||
})
|
})
|
||||||
.map(|(_, option)| *option)
|
.map(|(_, option)| **option)
|
||||||
.reduce(|acc, option| acc.merge(option));
|
.reduce(|acc, option| acc.merge(option));
|
||||||
let mut infos = Vec::new();
|
let mut infos = Vec::new();
|
||||||
|
|
||||||
@@ -941,6 +951,11 @@ fn format_value<'a>(
|
|||||||
infos: &mut Vec<MatchBounds>,
|
infos: &mut Vec<MatchBounds>,
|
||||||
compute_matches: bool,
|
compute_matches: bool,
|
||||||
) -> Value {
|
) -> Value {
|
||||||
|
// early skip recursive function if nothing needs to be changed.
|
||||||
|
if !format_options.as_ref().map_or(false, FormatOptions::should_format) && !compute_matches {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
match value {
|
match value {
|
||||||
Value::String(old_string) => {
|
Value::String(old_string) => {
|
||||||
let mut matcher = builder.build(&old_string);
|
let mut matcher = builder.build(&old_string);
|
||||||
|
@@ -72,7 +72,7 @@ impl<'m> MatcherBuilder<'m> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Copy, Clone, Default)]
|
#[derive(Copy, Clone, Default, Debug)]
|
||||||
pub struct FormatOptions {
|
pub struct FormatOptions {
|
||||||
pub highlight: bool,
|
pub highlight: bool,
|
||||||
pub crop: Option<usize>,
|
pub crop: Option<usize>,
|
||||||
@@ -82,6 +82,10 @@ impl FormatOptions {
|
|||||||
pub fn merge(self, other: Self) -> Self {
|
pub fn merge(self, other: Self) -> Self {
|
||||||
Self { highlight: self.highlight || other.highlight, crop: self.crop.or(other.crop) }
|
Self { highlight: self.highlight || other.highlight, crop: self.crop.or(other.crop) }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn should_format(&self) -> bool {
|
||||||
|
self.highlight || self.crop.is_some()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Debug)]
|
#[derive(Clone, Debug)]
|
||||||
|
Reference in New Issue
Block a user