mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 13:36:27 +00:00 
			
		
		
		
	Highlight ngram matches as well
This commit is contained in:
		| @@ -397,8 +397,8 @@ pub fn execute_search( | ||||
|         None | ||||
|     }; | ||||
|     let bucket_sort_output = if let Some(query_terms) = query_terms { | ||||
|         let graph = QueryGraph::from_query(ctx, &query_terms)?; | ||||
|         located_query_terms = Some(query_terms); | ||||
|         let (graph, new_located_query_terms) = QueryGraph::from_query(ctx, &query_terms)?; | ||||
|         located_query_terms = Some(new_located_query_terms); | ||||
|  | ||||
|         let ranking_rules = get_ranking_rules_for_query_graph_search( | ||||
|             ctx, | ||||
|   | ||||
| @@ -88,12 +88,15 @@ pub struct QueryGraph { | ||||
| } | ||||
|  | ||||
| impl QueryGraph { | ||||
|     /// Build the query graph from the parsed user search query. | ||||
|     /// Build the query graph from the parsed user search query, return an updated list of the located query terms | ||||
|     /// which contains ngrams. | ||||
|     pub fn from_query( | ||||
|         ctx: &mut SearchContext, | ||||
|         // NOTE: the terms here must be consecutive | ||||
|         terms: &[LocatedQueryTerm], | ||||
|     ) -> Result<QueryGraph> { | ||||
|     ) -> Result<(QueryGraph, Vec<LocatedQueryTerm>)> { | ||||
|         let mut new_located_query_terms = terms.to_vec(); | ||||
|  | ||||
|         let nbr_typos = number_of_typos_allowed(ctx)?; | ||||
|  | ||||
|         let mut nodes_data: Vec<QueryNodeData> = vec![QueryNodeData::Start, QueryNodeData::End]; | ||||
| @@ -107,10 +110,11 @@ impl QueryGraph { | ||||
|         let original_terms_len = terms.len(); | ||||
|         for term_idx in 0..original_terms_len { | ||||
|             let mut new_nodes = vec![]; | ||||
|  | ||||
|             let new_node_idx = add_node( | ||||
|                 &mut nodes_data, | ||||
|                 QueryNodeData::Term(LocatedQueryTermSubset { | ||||
|                     term_subset: QueryTermSubset::full(Interned::from_raw(term_idx as u16)), | ||||
|                     term_subset: QueryTermSubset::full(terms[term_idx].value), | ||||
|                     positions: terms[term_idx].positions.clone(), | ||||
|                     term_ids: term_idx as u8..=term_idx as u8, | ||||
|                 }), | ||||
| @@ -121,6 +125,7 @@ impl QueryGraph { | ||||
|                 if let Some(ngram) = | ||||
|                     query_term::make_ngram(ctx, &terms[term_idx - 1..=term_idx], &nbr_typos)? | ||||
|                 { | ||||
|                     new_located_query_terms.push(ngram.clone()); | ||||
|                     let ngram_idx = add_node( | ||||
|                         &mut nodes_data, | ||||
|                         QueryNodeData::Term(LocatedQueryTermSubset { | ||||
| @@ -136,6 +141,7 @@ impl QueryGraph { | ||||
|                 if let Some(ngram) = | ||||
|                     query_term::make_ngram(ctx, &terms[term_idx - 2..=term_idx], &nbr_typos)? | ||||
|                 { | ||||
|                     new_located_query_terms.push(ngram.clone()); | ||||
|                     let ngram_idx = add_node( | ||||
|                         &mut nodes_data, | ||||
|                         QueryNodeData::Term(LocatedQueryTermSubset { | ||||
| @@ -167,7 +173,7 @@ impl QueryGraph { | ||||
|         let mut graph = QueryGraph { root_node, end_node, nodes }; | ||||
|         graph.build_initial_edges(); | ||||
|  | ||||
|         Ok(graph) | ||||
|         Ok((graph, new_located_query_terms)) | ||||
|     } | ||||
|  | ||||
|     /// Remove the given nodes, connecting all their predecessors to all their successors. | ||||
|   | ||||
		Reference in New Issue
	
	Block a user