mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 21:16:28 +00:00 
			
		
		
		
	limit the search in the FST
This commit is contained in:
		| @@ -326,20 +326,19 @@ pub fn traverse_query_tree<'o, 'txn>( | |||||||
|     { |     { | ||||||
|         let before = Instant::now(); |         let before = Instant::now(); | ||||||
|  |  | ||||||
|         // let byte = query.as_bytes()[0]; |  | ||||||
|         // let mut stream = if byte == u8::max_value() { |  | ||||||
|         //     words.search(&dfa).ge(&[byte]).into_stream() |  | ||||||
|         // } else { |  | ||||||
|         //     words.search(&dfa).ge(&[byte]).lt(&[byte + 1]).into_stream() |  | ||||||
|         // }; |  | ||||||
|  |  | ||||||
|         let Query { id, prefix, kind } = query; |         let Query { id, prefix, kind } = query; | ||||||
|         let docids = match kind { |         let docids = match kind { | ||||||
|             QueryKind::Tolerant(word) => { |             QueryKind::Tolerant(word) => { | ||||||
|                 let dfa = if *prefix { build_prefix_dfa(word) } else { build_dfa(word) }; |                 let dfa = if *prefix { build_prefix_dfa(word) } else { build_dfa(word) }; | ||||||
|  |  | ||||||
|  |                 let byte = word.as_bytes()[0]; | ||||||
|  |                 let mut stream = if byte == u8::max_value() { | ||||||
|  |                     words_set.search(&dfa).ge(&[byte]).into_stream() | ||||||
|  |                 } else { | ||||||
|  |                     words_set.search(&dfa).ge(&[byte]).lt(&[byte + 1]).into_stream() | ||||||
|  |                 }; | ||||||
|  |  | ||||||
|                 let mut docids = Vec::new(); |                 let mut docids = Vec::new(); | ||||||
|                 let mut stream = words_set.search(&dfa).into_stream(); |  | ||||||
|                 while let Some(input) = stream.next() { |                 while let Some(input) = stream.next() { | ||||||
|                     if let Some(matches) = pls.postings_list(reader, input)? { |                     if let Some(matches) = pls.postings_list(reader, input)? { | ||||||
|                         docids.extend(matches.iter().map(|d| d.document_id)) |                         docids.extend(matches.iter().map(|d| d.document_id)) | ||||||
| @@ -352,8 +351,14 @@ pub fn traverse_query_tree<'o, 'txn>( | |||||||
|                 // TODO support prefix and non-prefix exact DFA |                 // TODO support prefix and non-prefix exact DFA | ||||||
|                 let dfa = build_exact_dfa(word); |                 let dfa = build_exact_dfa(word); | ||||||
|  |  | ||||||
|  |                 let byte = word.as_bytes()[0]; | ||||||
|  |                 let mut stream = if byte == u8::max_value() { | ||||||
|  |                     words_set.search(&dfa).ge(&[byte]).into_stream() | ||||||
|  |                 } else { | ||||||
|  |                     words_set.search(&dfa).ge(&[byte]).lt(&[byte + 1]).into_stream() | ||||||
|  |                 }; | ||||||
|  |  | ||||||
|                 let mut docids = Vec::new(); |                 let mut docids = Vec::new(); | ||||||
|                 let mut stream = words_set.search(&dfa).into_stream(); |  | ||||||
|                 while let Some(input) = stream.next() { |                 while let Some(input) = stream.next() { | ||||||
|                     if let Some(matches) = pls.postings_list(reader, input)? { |                     if let Some(matches) = pls.postings_list(reader, input)? { | ||||||
|                         docids.extend(matches.iter().map(|d| d.document_id)) |                         docids.extend(matches.iter().map(|d| d.document_id)) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user