mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 13:36:27 +00:00 
			
		
		
		
	update heed
This commit is contained in:
		| @@ -18,7 +18,7 @@ either = "1.5.3" | ||||
| env_logger = "0.8.2" | ||||
| fst = "0.4.4" | ||||
| hashbrown = { version = "0.9.0", features = ["serde"] } | ||||
| heed = "0.8.0" | ||||
| heed = "0.10.5" | ||||
| indexmap = { version = "1.3.2", features = ["serde-1"] } | ||||
| intervaltree = "0.2.5" | ||||
| itertools = "0.9.0" | ||||
|   | ||||
| @@ -61,7 +61,7 @@ pub trait Criterion { | ||||
| } | ||||
|  | ||||
| pub struct ContextMut<'h, 'p, 'tag, 'txn, 'q> { | ||||
|     pub reader: &'h heed::RoTxn<MainT>, | ||||
|     pub reader: &'h heed::RoTxn<'h, MainT>, | ||||
|     pub postings_lists: &'p mut SmallArena<'tag, PostingsListView<'txn>>, | ||||
|     pub query_mapping: &'q HashMap<QueryId, Range<usize>>, | ||||
|     pub documents_fields_counts_store: store::DocumentsFieldsCounts, | ||||
|   | ||||
| @@ -22,11 +22,11 @@ type ArcSwapFn = arc_swap::ArcSwapOption<BoxUpdateFn>; | ||||
|  | ||||
| type SerdeDatetime = SerdeBincode<DateTime<Utc>>; | ||||
|  | ||||
| pub type MainWriter<'a> = heed::RwTxn<'a, MainT>; | ||||
| pub type MainReader = heed::RoTxn<MainT>; | ||||
| pub type MainWriter<'a, 'b> = heed::RwTxn<'a, 'b, MainT>; | ||||
| pub type MainReader<'a, 'b> = heed::RoTxn<'a, MainT>; | ||||
|  | ||||
| pub type UpdateWriter<'a> = heed::RwTxn<'a, UpdateT>; | ||||
| pub type UpdateReader = heed::RoTxn<UpdateT>; | ||||
| pub type UpdateWriter<'a, 'b> = heed::RwTxn<'a, 'b, UpdateT>; | ||||
| pub type UpdateReader<'a> = heed::RoTxn<'a, UpdateT>; | ||||
|  | ||||
| const LAST_UPDATE_KEY: &str = "last-update"; | ||||
|  | ||||
|   | ||||
| @@ -51,7 +51,7 @@ impl From<heed::Error> for DeserializerError { | ||||
|  | ||||
| pub struct Deserializer<'a> { | ||||
|     pub document_id: DocumentId, | ||||
|     pub reader: &'a heed::RoTxn<MainT>, | ||||
|     pub reader: &'a heed::RoTxn<'a, MainT>, | ||||
|     pub documents_fields: DocumentsFields, | ||||
|     pub schema: &'a Schema, | ||||
|     pub fields: Option<&'a HashSet<FieldId>>, | ||||
|   | ||||
| @@ -33,7 +33,7 @@ impl DocsWords { | ||||
|         self.docs_words.clear(writer) | ||||
|     } | ||||
|  | ||||
|     pub fn doc_words(self, reader: &heed::RoTxn<MainT>, document_id: DocumentId) -> ZResult<FstSetCow> { | ||||
|     pub fn doc_words<'a>(self, reader: &'a heed::RoTxn<'a, MainT>, document_id: DocumentId) -> ZResult<FstSetCow> { | ||||
|         let document_id = BEU32::new(document_id.0); | ||||
|         match self.docs_words.get(reader, &document_id)? { | ||||
|             Some(bytes) => Ok(fst::Set::new(bytes).unwrap().map_data(Cow::Borrowed).unwrap()), | ||||
|   | ||||
| @@ -2,7 +2,7 @@ use std::borrow::Cow; | ||||
| use std::collections::HashMap; | ||||
| use std::mem; | ||||
|  | ||||
| use heed::{RwTxn, RoTxn, RoRange, types::Str, BytesEncode, BytesDecode}; | ||||
| use heed::{RwTxn, RoTxn, RoPrefix, types::Str, BytesEncode, BytesDecode}; | ||||
| use sdset::{SetBuf, Set, SetOperation}; | ||||
|  | ||||
| use meilisearch_types::DocumentId; | ||||
| @@ -62,7 +62,7 @@ impl Facets { | ||||
|         Ok(self.facets.put(writer, &facet_key, &(facet_value, doc_ids))?) | ||||
|     } | ||||
|  | ||||
|     pub fn field_document_ids<'txn>(&self, reader: &'txn RoTxn<MainT>, field_id: FieldId) -> MResult<RoRange<'txn, FacetKey, FacetData>> { | ||||
|     pub fn field_document_ids<'txn>(&self, reader: &'txn RoTxn<MainT>, field_id: FieldId) -> MResult<RoPrefix<'txn, FacetKey, FacetData>> { | ||||
|         Ok(self.facets.prefix_iter(reader, &FacetKey::new(field_id, String::new()))?) | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -143,7 +143,7 @@ impl Main { | ||||
|         self.put_external_docids(writer, &external_docids) | ||||
|     } | ||||
|  | ||||
|     pub fn external_docids(self, reader: &heed::RoTxn<MainT>) -> MResult<FstMapCow> { | ||||
|     pub fn external_docids<'a>(self, reader: &'a heed::RoTxn<'a, MainT>) -> MResult<FstMapCow> { | ||||
|         match self.main.get::<_, Str, ByteSlice>(reader, EXTERNAL_DOCIDS_KEY)? { | ||||
|             Some(bytes) => Ok(fst::Map::new(bytes).unwrap().map_data(Cow::Borrowed).unwrap()), | ||||
|             None => Ok(fst::Map::default().map_data(Cow::Owned).unwrap()), | ||||
| @@ -155,7 +155,7 @@ impl Main { | ||||
|         Ok(external_ids.get(external_docid).map(|id| DocumentId(id as u32))) | ||||
|     } | ||||
|  | ||||
|     pub fn words_fst(self, reader: &heed::RoTxn<MainT>) -> MResult<FstSetCow> { | ||||
|     pub fn words_fst<'a>(self, reader: &'a heed::RoTxn<'a, MainT>) -> MResult<FstSetCow> { | ||||
|         match self.main.get::<_, Str, ByteSlice>(reader, WORDS_KEY)? { | ||||
|             Some(bytes) => Ok(fst::Set::new(bytes).unwrap().map_data(Cow::Borrowed).unwrap()), | ||||
|             None => Ok(fst::Set::default().map_data(Cow::Owned).unwrap()), | ||||
| @@ -170,7 +170,7 @@ impl Main { | ||||
|         Ok(self.main.put::<_, Str, CowSlice<DocumentId>>(writer, SORTED_DOCUMENT_IDS_CACHE_KEY, documents_ids)?) | ||||
|     } | ||||
|  | ||||
|     pub fn sorted_document_ids_cache(self, reader: &heed::RoTxn<MainT>) -> MResult<Option<Cow<[DocumentId]>>> { | ||||
|     pub fn sorted_document_ids_cache<'a>(self, reader: &'a heed::RoTxn<'a, MainT>) -> MResult<Option<Cow<[DocumentId]>>> { | ||||
|         Ok(self.main.get::<_, Str, CowSlice<DocumentId>>(reader, SORTED_DOCUMENT_IDS_CACHE_KEY)?) | ||||
|     } | ||||
|  | ||||
| @@ -199,7 +199,7 @@ impl Main { | ||||
|         Ok(self.main.put::<_, Str, ByteSlice>(writer, SYNONYMS_KEY, bytes)?) | ||||
|     } | ||||
|  | ||||
|     pub(crate) fn synonyms_fst(self, reader: &heed::RoTxn<MainT>) -> MResult<FstSetCow> { | ||||
|     pub(crate) fn synonyms_fst<'a>(self, reader: &'a heed::RoTxn<'a, MainT>) -> MResult<FstSetCow> { | ||||
|         match self.main.get::<_, Str, ByteSlice>(reader, SYNONYMS_KEY)? { | ||||
|             Some(bytes) => Ok(fst::Set::new(bytes).unwrap().map_data(Cow::Borrowed).unwrap()), | ||||
|             None => Ok(fst::Set::default().map_data(Cow::Owned).unwrap()), | ||||
| @@ -219,7 +219,7 @@ impl Main { | ||||
|         Ok(self.main.put::<_, Str, ByteSlice>(writer, STOP_WORDS_KEY, bytes)?) | ||||
|     } | ||||
|  | ||||
|     pub(crate) fn stop_words_fst(self, reader: &heed::RoTxn<MainT>) -> MResult<FstSetCow> { | ||||
|     pub(crate) fn stop_words_fst<'a>(self, reader: &'a heed::RoTxn<'a, MainT>) -> MResult<FstSetCow> { | ||||
|         match self.main.get::<_, Str, ByteSlice>(reader, STOP_WORDS_KEY)? { | ||||
|             Some(bytes) => Ok(fst::Set::new(bytes).unwrap().map_data(Cow::Borrowed).unwrap()), | ||||
|             None => Ok(fst::Set::default().map_data(Cow::Owned).unwrap()), | ||||
|   | ||||
| @@ -146,8 +146,8 @@ where A: AsRef<[u8]>, | ||||
|     Ok(()) | ||||
| } | ||||
|  | ||||
| pub fn apply_addition<'a, 'b>( | ||||
|     writer: &'a mut heed::RwTxn<'b, MainT>, | ||||
| pub fn apply_addition<'a, 'b, 'c>( | ||||
|     writer: &'a mut heed::RwTxn<'b, 'c, MainT>, | ||||
|     index: &store::Index, | ||||
|     new_documents: Vec<IndexMap<String, Value>>, | ||||
|     partial: bool | ||||
| @@ -272,16 +272,16 @@ pub fn apply_addition<'a, 'b>( | ||||
|     Ok(()) | ||||
| } | ||||
|  | ||||
| pub fn apply_documents_partial_addition<'a, 'b>( | ||||
|     writer: &'a mut heed::RwTxn<'b, MainT>, | ||||
| pub fn apply_documents_partial_addition<'a, 'b, 'c>( | ||||
|     writer: &'a mut heed::RwTxn<'b, 'c, MainT>, | ||||
|     index: &store::Index, | ||||
|     new_documents: Vec<IndexMap<String, Value>>, | ||||
| ) -> MResult<()> { | ||||
|     apply_addition(writer, index, new_documents, true) | ||||
| } | ||||
|  | ||||
| pub fn apply_documents_addition<'a, 'b>( | ||||
|     writer: &'a mut heed::RwTxn<'b, MainT>, | ||||
| pub fn apply_documents_addition<'a, 'b, 'c>( | ||||
|     writer: &'a mut heed::RwTxn<'b, 'c, MainT>, | ||||
|     index: &store::Index, | ||||
|     new_documents: Vec<IndexMap<String, Value>>, | ||||
| ) -> MResult<()> { | ||||
|   | ||||
| @@ -212,8 +212,8 @@ pub fn next_update_id( | ||||
|     Ok(new_update_id) | ||||
| } | ||||
|  | ||||
| pub fn update_task<'a, 'b>( | ||||
|     writer: &'a mut heed::RwTxn<'b, MainT>, | ||||
| pub fn update_task<'a, 'b, 'c>( | ||||
|     writer: &'a mut heed::RwTxn<'b, 'c, MainT>, | ||||
|     index: &store::Index, | ||||
|     update_id: u64, | ||||
|     update: Update, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user