mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 05:26:27 +00:00 
			
		
		
		
	Plug the faceting.max_values_per_facet setting
This commit is contained in:
		| @@ -8,7 +8,7 @@ use std::sync::Arc; | ||||
| use fst::IntoStreamer; | ||||
| use milli::heed::{EnvOpenOptions, RoTxn}; | ||||
| use milli::update::{IndexerConfig, Setting}; | ||||
| use milli::{obkv_to_json, FieldDistribution}; | ||||
| use milli::{obkv_to_json, FieldDistribution, DEFAULT_VALUES_PER_FACET}; | ||||
| use serde::{Deserialize, Serialize}; | ||||
| use serde_json::{Map, Value}; | ||||
| use time::OffsetDateTime; | ||||
| @@ -18,7 +18,7 @@ use crate::EnvSizer; | ||||
|  | ||||
| use super::error::IndexError; | ||||
| use super::error::Result; | ||||
| use super::updates::{MinWordSizeTyposSetting, TypoSettings}; | ||||
| use super::updates::{FacetingSettings, MinWordSizeTyposSetting, TypoSettings}; | ||||
| use super::{Checked, Settings}; | ||||
|  | ||||
| pub type Document = Map<String, Value>; | ||||
| @@ -193,6 +193,15 @@ impl Index { | ||||
|             disable_on_attributes: Setting::Set(disabled_attributes), | ||||
|         }; | ||||
|  | ||||
|         let faceting = FacetingSettings { | ||||
|             max_values_per_facet: Setting::Set( | ||||
|                 self.max_values_per_facet(txn)? | ||||
|                     .unwrap_or(DEFAULT_VALUES_PER_FACET), | ||||
|             ), | ||||
|         }; | ||||
|  | ||||
|         dbg!(&faceting); | ||||
|  | ||||
|         Ok(Settings { | ||||
|             displayed_attributes: match displayed_attributes { | ||||
|                 Some(attrs) => Setting::Set(attrs), | ||||
| @@ -212,6 +221,7 @@ impl Index { | ||||
|             }, | ||||
|             synonyms: Setting::Set(synonyms), | ||||
|             typo_tolerance: Setting::Set(typo_tolerance), | ||||
|             faceting: Setting::Set(faceting), | ||||
|             _kind: PhantomData, | ||||
|         }) | ||||
|     } | ||||
|   | ||||
| @@ -7,6 +7,7 @@ use either::Either; | ||||
| use milli::tokenizer::TokenizerBuilder; | ||||
| use milli::{ | ||||
|     AscDesc, FieldId, FieldsIdsMap, Filter, FormatOptions, MatchBounds, MatcherBuilder, SortError, | ||||
|     DEFAULT_VALUES_PER_FACET, | ||||
| }; | ||||
| use regex::Regex; | ||||
| use serde::{Deserialize, Serialize}; | ||||
| @@ -223,6 +224,12 @@ impl Index { | ||||
|         let facet_distribution = match query.facets { | ||||
|             Some(ref fields) => { | ||||
|                 let mut facet_distribution = self.facets_distribution(&rtxn); | ||||
|  | ||||
|                 let max_values_by_facet = self | ||||
|                     .max_values_per_facet(&rtxn)? | ||||
|                     .unwrap_or(DEFAULT_VALUES_PER_FACET); | ||||
|                 facet_distribution.max_values_per_facet(max_values_by_facet); | ||||
|  | ||||
|                 if fields.iter().all(|f| f != "*") { | ||||
|                     facet_distribution.facets(fields); | ||||
|                 } | ||||
|   | ||||
| @@ -484,6 +484,7 @@ pub(crate) mod test { | ||||
|             synonyms: Setting::NotSet, | ||||
|             distinct_attribute: Setting::NotSet, | ||||
|             typo_tolerance: Setting::NotSet, | ||||
|             faceting: Setting::NotSet, | ||||
|             _kind: PhantomData::<Unchecked>, | ||||
|         }; | ||||
|  | ||||
| @@ -506,6 +507,7 @@ pub(crate) mod test { | ||||
|             synonyms: Setting::NotSet, | ||||
|             distinct_attribute: Setting::NotSet, | ||||
|             typo_tolerance: Setting::NotSet, | ||||
|             faceting: Setting::NotSet, | ||||
|             _kind: PhantomData::<Unchecked>, | ||||
|         }; | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user