mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 21:16:28 +00:00 
			
		
		
		
	Move to heed 0.1.0
This commit is contained in:
		| @@ -12,6 +12,7 @@ crossbeam-channel = "0.3.9" | |||||||
| deunicode = "1.0.0" | deunicode = "1.0.0" | ||||||
| env_logger = "0.7.0" | env_logger = "0.7.0" | ||||||
| hashbrown = { version = "0.6.0", features = ["serde"] } | hashbrown = { version = "0.6.0", features = ["serde"] } | ||||||
|  | heed = "0.1.0" | ||||||
| log = "0.4.8" | log = "0.4.8" | ||||||
| meilidb-schema = { path = "../meilidb-schema", version = "0.1.0" } | meilidb-schema = { path = "../meilidb-schema", version = "0.1.0" } | ||||||
| meilidb-tokenizer = { path = "../meilidb-tokenizer", version = "0.1.0" } | meilidb-tokenizer = { path = "../meilidb-tokenizer", version = "0.1.0" } | ||||||
| @@ -24,11 +25,6 @@ siphasher = "0.3.0" | |||||||
| slice-group-by = "0.2.6" | slice-group-by = "0.2.6" | ||||||
| zerocopy = "0.2.8" | zerocopy = "0.2.8" | ||||||
|  |  | ||||||
| [dependencies.zlmdb] |  | ||||||
| package = "zerocopy-lmdb" |  | ||||||
| git = "https://github.com/Kerollmops/zerocopy-lmdb.git" |  | ||||||
| branch = "master" |  | ||||||
|  |  | ||||||
| [dependencies.levenshtein_automata] | [dependencies.levenshtein_automata] | ||||||
| git = "https://github.com/Kerollmops/levenshtein-automata.git" | git = "https://github.com/Kerollmops/levenshtein-automata.git" | ||||||
| branch = "arc-byte-slice" | branch = "arc-byte-slice" | ||||||
|   | |||||||
| @@ -23,7 +23,7 @@ pub struct AutomatonProducer { | |||||||
|  |  | ||||||
| impl AutomatonProducer { | impl AutomatonProducer { | ||||||
|     pub fn new( |     pub fn new( | ||||||
|         reader: &zlmdb::RoTxn, |         reader: &heed::RoTxn, | ||||||
|         query: &str, |         query: &str, | ||||||
|         main_store: store::Main, |         main_store: store::Main, | ||||||
|         synonyms_store: store::Synonyms, |         synonyms_store: store::Synonyms, | ||||||
| @@ -103,7 +103,7 @@ pub fn normalize_str(string: &str) -> String { | |||||||
| } | } | ||||||
|  |  | ||||||
| fn generate_automatons( | fn generate_automatons( | ||||||
|     reader: &zlmdb::RoTxn, |     reader: &heed::RoTxn, | ||||||
|     query: &str, |     query: &str, | ||||||
|     main_store: store::Main, |     main_store: store::Main, | ||||||
|     synonym_store: store::Synonyms, |     synonym_store: store::Synonyms, | ||||||
|   | |||||||
| @@ -5,9 +5,9 @@ use std::sync::{Arc, RwLock}; | |||||||
| use std::{fs, thread}; | use std::{fs, thread}; | ||||||
|  |  | ||||||
| use crossbeam_channel::Receiver; | use crossbeam_channel::Receiver; | ||||||
|  | use heed::types::{Str, Unit}; | ||||||
|  | use heed::{CompactionOption, Result as ZResult}; | ||||||
| use log::{debug, error}; | use log::{debug, error}; | ||||||
| use zlmdb::types::{Str, Unit}; |  | ||||||
| use zlmdb::{CompactionOption, Result as ZResult}; |  | ||||||
|  |  | ||||||
| use crate::{store, update, Index, MResult}; | use crate::{store, update, Index, MResult}; | ||||||
|  |  | ||||||
| @@ -15,18 +15,13 @@ pub type BoxUpdateFn = Box<dyn Fn(update::UpdateResult) + Send + Sync + 'static> | |||||||
| type ArcSwapFn = arc_swap::ArcSwapOption<BoxUpdateFn>; | type ArcSwapFn = arc_swap::ArcSwapOption<BoxUpdateFn>; | ||||||
|  |  | ||||||
| pub struct Database { | pub struct Database { | ||||||
|     pub env: zlmdb::Env, |     pub env: heed::Env, | ||||||
|     common_store: zlmdb::DynDatabase, |     common_store: heed::PolyDatabase, | ||||||
|     indexes_store: zlmdb::Database<Str, Unit>, |     indexes_store: heed::Database<Str, Unit>, | ||||||
|     indexes: RwLock<HashMap<String, (Index, Arc<ArcSwapFn>, thread::JoinHandle<()>)>>, |     indexes: RwLock<HashMap<String, (Index, Arc<ArcSwapFn>, thread::JoinHandle<()>)>>, | ||||||
| } | } | ||||||
|  |  | ||||||
| fn update_awaiter( | fn update_awaiter(receiver: Receiver<()>, env: heed::Env, update_fn: Arc<ArcSwapFn>, index: Index) { | ||||||
|     receiver: Receiver<()>, |  | ||||||
|     env: zlmdb::Env, |  | ||||||
|     update_fn: Arc<ArcSwapFn>, |  | ||||||
|     index: Index, |  | ||||||
| ) { |  | ||||||
|     for () in receiver { |     for () in receiver { | ||||||
|         // consume all updates in order (oldest first) |         // consume all updates in order (oldest first) | ||||||
|         loop { |         loop { | ||||||
| @@ -67,7 +62,7 @@ impl Database { | |||||||
|     pub fn open_or_create(path: impl AsRef<Path>) -> MResult<Database> { |     pub fn open_or_create(path: impl AsRef<Path>) -> MResult<Database> { | ||||||
|         fs::create_dir_all(path.as_ref())?; |         fs::create_dir_all(path.as_ref())?; | ||||||
|  |  | ||||||
|         let env = zlmdb::EnvOpenOptions::new() |         let env = heed::EnvOpenOptions::new() | ||||||
|             .map_size(10 * 1024 * 1024 * 1024) // 10GB |             .map_size(10 * 1024 * 1024 * 1024) // 10GB | ||||||
|             .max_dbs(3000) |             .max_dbs(3000) | ||||||
|             .open(path)?; |             .open(path)?; | ||||||
| @@ -199,7 +194,7 @@ impl Database { | |||||||
|         Ok(indexes.keys().cloned().collect()) |         Ok(indexes.keys().cloned().collect()) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn common_store(&self) -> zlmdb::DynDatabase { |     pub fn common_store(&self) -> heed::PolyDatabase { | ||||||
|         self.common_store |         self.common_store | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ pub enum Error { | |||||||
|     SchemaMissing, |     SchemaMissing, | ||||||
|     WordIndexMissing, |     WordIndexMissing, | ||||||
|     MissingDocumentId, |     MissingDocumentId, | ||||||
|     Zlmdb(zlmdb::Error), |     Zlmdb(heed::Error), | ||||||
|     Fst(fst::Error), |     Fst(fst::Error), | ||||||
|     SerdeJson(SerdeJsonError), |     SerdeJson(SerdeJsonError), | ||||||
|     Bincode(bincode::Error), |     Bincode(bincode::Error), | ||||||
| @@ -27,8 +27,8 @@ impl From<io::Error> for Error { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| impl From<zlmdb::Error> for Error { | impl From<heed::Error> for Error { | ||||||
|     fn from(error: zlmdb::Error) -> Error { |     fn from(error: heed::Error) -> Error { | ||||||
|         Error::Zlmdb(error) |         Error::Zlmdb(error) | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -79,7 +79,7 @@ impl fmt::Display for Error { | |||||||
|             SchemaMissing => write!(f, "this index does not have a schema"), |             SchemaMissing => write!(f, "this index does not have a schema"), | ||||||
|             WordIndexMissing => write!(f, "this index does not have a word index"), |             WordIndexMissing => write!(f, "this index does not have a word index"), | ||||||
|             MissingDocumentId => write!(f, "document id is missing"), |             MissingDocumentId => write!(f, "document id is missing"), | ||||||
|             Zlmdb(e) => write!(f, "zlmdb error; {}", e), |             Zlmdb(e) => write!(f, "heed error; {}", e), | ||||||
|             Fst(e) => write!(f, "fst error; {}", e), |             Fst(e) => write!(f, "fst error; {}", e), | ||||||
|             SerdeJson(e) => write!(f, "serde json error; {}", e), |             SerdeJson(e) => write!(f, "serde json error; {}", e), | ||||||
|             Bincode(e) => write!(f, "bincode error; {}", e), |             Bincode(e) => write!(f, "bincode error; {}", e), | ||||||
|   | |||||||
| @@ -137,7 +137,7 @@ fn multiword_rewrite_matches( | |||||||
| } | } | ||||||
|  |  | ||||||
| fn fetch_raw_documents( | fn fetch_raw_documents( | ||||||
|     reader: &zlmdb::RoTxn, |     reader: &heed::RoTxn, | ||||||
|     automatons: &[Automaton], |     automatons: &[Automaton], | ||||||
|     query_enhancer: &QueryEnhancer, |     query_enhancer: &QueryEnhancer, | ||||||
|     searchables: Option<&ReorderedAttrs>, |     searchables: Option<&ReorderedAttrs>, | ||||||
| @@ -285,7 +285,7 @@ impl<'c, 'f, 'd> QueryBuilder<'c, 'f, 'd> { | |||||||
|  |  | ||||||
|     pub fn query( |     pub fn query( | ||||||
|         self, |         self, | ||||||
|         reader: &zlmdb::RoTxn, |         reader: &heed::RoTxn, | ||||||
|         query: &str, |         query: &str, | ||||||
|         range: Range<usize>, |         range: Range<usize>, | ||||||
|     ) -> MResult<Vec<Document>> { |     ) -> MResult<Vec<Document>> { | ||||||
| @@ -323,7 +323,7 @@ impl<'c, 'f, 'd> QueryBuilder<'c, 'f, 'd> { | |||||||
| } | } | ||||||
|  |  | ||||||
| fn raw_query<'c, FI>( | fn raw_query<'c, FI>( | ||||||
|     reader: &zlmdb::RoTxn, |     reader: &heed::RoTxn, | ||||||
|  |  | ||||||
|     query: &str, |     query: &str, | ||||||
|     range: Range<usize>, |     range: Range<usize>, | ||||||
| @@ -454,7 +454,7 @@ where | |||||||
| } | } | ||||||
|  |  | ||||||
| fn raw_query_with_distinct<'c, FI, FD>( | fn raw_query_with_distinct<'c, FI, FD>( | ||||||
|     reader: &zlmdb::RoTxn, |     reader: &heed::RoTxn, | ||||||
|  |  | ||||||
|     query: &str, |     query: &str, | ||||||
|     range: Range<usize>, |     range: Range<usize>, | ||||||
|   | |||||||
| @@ -14,7 +14,7 @@ use crate::DocumentId; | |||||||
| #[derive(Debug)] | #[derive(Debug)] | ||||||
| pub enum DeserializerError { | pub enum DeserializerError { | ||||||
|     SerdeJson(SerdeJsonError), |     SerdeJson(SerdeJsonError), | ||||||
|     Zlmdb(zlmdb::Error), |     Zlmdb(heed::Error), | ||||||
|     Custom(String), |     Custom(String), | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -28,7 +28,7 @@ impl fmt::Display for DeserializerError { | |||||||
|     fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { |     fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { | ||||||
|         match self { |         match self { | ||||||
|             DeserializerError::SerdeJson(e) => write!(f, "serde json related error: {}", e), |             DeserializerError::SerdeJson(e) => write!(f, "serde json related error: {}", e), | ||||||
|             DeserializerError::Zlmdb(e) => write!(f, "zlmdb related error: {}", e), |             DeserializerError::Zlmdb(e) => write!(f, "heed related error: {}", e), | ||||||
|             DeserializerError::Custom(s) => f.write_str(s), |             DeserializerError::Custom(s) => f.write_str(s), | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -42,15 +42,15 @@ impl From<SerdeJsonError> for DeserializerError { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| impl From<zlmdb::Error> for DeserializerError { | impl From<heed::Error> for DeserializerError { | ||||||
|     fn from(error: zlmdb::Error) -> DeserializerError { |     fn from(error: heed::Error) -> DeserializerError { | ||||||
|         DeserializerError::Zlmdb(error) |         DeserializerError::Zlmdb(error) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| pub struct Deserializer<'a> { | pub struct Deserializer<'a> { | ||||||
|     pub document_id: DocumentId, |     pub document_id: DocumentId, | ||||||
|     pub reader: &'a zlmdb::RoTxn, |     pub reader: &'a heed::RoTxn, | ||||||
|     pub documents_fields: DocumentsFields, |     pub documents_fields: DocumentsFields, | ||||||
|     pub schema: &'a Schema, |     pub schema: &'a Schema, | ||||||
|     pub attributes: Option<&'a HashSet<SchemaAttr>>, |     pub attributes: Option<&'a HashSet<SchemaAttr>>, | ||||||
|   | |||||||
| @@ -35,7 +35,7 @@ use crate::{DocumentId, ParseNumberError}; | |||||||
| pub enum SerializerError { | pub enum SerializerError { | ||||||
|     DocumentIdNotFound, |     DocumentIdNotFound, | ||||||
|     InvalidDocumentIdType, |     InvalidDocumentIdType, | ||||||
|     Zlmdb(zlmdb::Error), |     Zlmdb(heed::Error), | ||||||
|     SerdeJson(SerdeJsonError), |     SerdeJson(SerdeJsonError), | ||||||
|     ParseNumber(ParseNumberError), |     ParseNumber(ParseNumberError), | ||||||
|     UnserializableType { type_name: &'static str }, |     UnserializableType { type_name: &'static str }, | ||||||
| @@ -59,7 +59,7 @@ impl fmt::Display for SerializerError { | |||||||
|             SerializerError::InvalidDocumentIdType => { |             SerializerError::InvalidDocumentIdType => { | ||||||
|                 f.write_str("document identifier can only be of type string or number") |                 f.write_str("document identifier can only be of type string or number") | ||||||
|             } |             } | ||||||
|             SerializerError::Zlmdb(e) => write!(f, "zlmdb related error: {}", e), |             SerializerError::Zlmdb(e) => write!(f, "heed related error: {}", e), | ||||||
|             SerializerError::SerdeJson(e) => write!(f, "serde json error: {}", e), |             SerializerError::SerdeJson(e) => write!(f, "serde json error: {}", e), | ||||||
|             SerializerError::ParseNumber(e) => { |             SerializerError::ParseNumber(e) => { | ||||||
|                 write!(f, "error while trying to parse a number: {}", e) |                 write!(f, "error while trying to parse a number: {}", e) | ||||||
| @@ -92,8 +92,8 @@ impl From<SerdeJsonError> for SerializerError { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| impl From<zlmdb::Error> for SerializerError { | impl From<heed::Error> for SerializerError { | ||||||
|     fn from(error: zlmdb::Error) -> SerializerError { |     fn from(error: heed::Error) -> SerializerError { | ||||||
|         SerializerError::Zlmdb(error) |         SerializerError::Zlmdb(error) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,18 +1,18 @@ | |||||||
| use super::BEU64; | use super::BEU64; | ||||||
| use crate::DocumentId; | use crate::DocumentId; | ||||||
|  | use heed::types::{ByteSlice, OwnedType}; | ||||||
|  | use heed::Result as ZResult; | ||||||
| use std::sync::Arc; | use std::sync::Arc; | ||||||
| use zlmdb::types::{ByteSlice, OwnedType}; |  | ||||||
| use zlmdb::Result as ZResult; |  | ||||||
|  |  | ||||||
| #[derive(Copy, Clone)] | #[derive(Copy, Clone)] | ||||||
| pub struct DocsWords { | pub struct DocsWords { | ||||||
|     pub(crate) docs_words: zlmdb::Database<OwnedType<BEU64>, ByteSlice>, |     pub(crate) docs_words: heed::Database<OwnedType<BEU64>, ByteSlice>, | ||||||
| } | } | ||||||
|  |  | ||||||
| impl DocsWords { | impl DocsWords { | ||||||
|     pub fn put_doc_words( |     pub fn put_doc_words( | ||||||
|         self, |         self, | ||||||
|         writer: &mut zlmdb::RwTxn, |         writer: &mut heed::RwTxn, | ||||||
|         document_id: DocumentId, |         document_id: DocumentId, | ||||||
|         words: &fst::Set, |         words: &fst::Set, | ||||||
|     ) -> ZResult<()> { |     ) -> ZResult<()> { | ||||||
| @@ -21,18 +21,14 @@ impl DocsWords { | |||||||
|         self.docs_words.put(writer, &document_id, bytes) |         self.docs_words.put(writer, &document_id, bytes) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn del_doc_words( |     pub fn del_doc_words(self, writer: &mut heed::RwTxn, document_id: DocumentId) -> ZResult<bool> { | ||||||
|         self, |  | ||||||
|         writer: &mut zlmdb::RwTxn, |  | ||||||
|         document_id: DocumentId, |  | ||||||
|     ) -> ZResult<bool> { |  | ||||||
|         let document_id = BEU64::new(document_id.0); |         let document_id = BEU64::new(document_id.0); | ||||||
|         self.docs_words.delete(writer, &document_id) |         self.docs_words.delete(writer, &document_id) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn doc_words( |     pub fn doc_words( | ||||||
|         self, |         self, | ||||||
|         reader: &zlmdb::RoTxn, |         reader: &heed::RoTxn, | ||||||
|         document_id: DocumentId, |         document_id: DocumentId, | ||||||
|     ) -> ZResult<Option<fst::Set>> { |     ) -> ZResult<Option<fst::Set>> { | ||||||
|         let document_id = BEU64::new(document_id.0); |         let document_id = BEU64::new(document_id.0); | ||||||
|   | |||||||
| @@ -1,19 +1,19 @@ | |||||||
|  | use heed::types::{ByteSlice, OwnedType}; | ||||||
|  | use heed::Result as ZResult; | ||||||
| use meilidb_schema::SchemaAttr; | use meilidb_schema::SchemaAttr; | ||||||
| use zlmdb::types::{ByteSlice, OwnedType}; |  | ||||||
| use zlmdb::Result as ZResult; |  | ||||||
|  |  | ||||||
| use super::DocumentAttrKey; | use super::DocumentAttrKey; | ||||||
| use crate::DocumentId; | use crate::DocumentId; | ||||||
|  |  | ||||||
| #[derive(Copy, Clone)] | #[derive(Copy, Clone)] | ||||||
| pub struct DocumentsFields { | pub struct DocumentsFields { | ||||||
|     pub(crate) documents_fields: zlmdb::Database<OwnedType<DocumentAttrKey>, ByteSlice>, |     pub(crate) documents_fields: heed::Database<OwnedType<DocumentAttrKey>, ByteSlice>, | ||||||
| } | } | ||||||
|  |  | ||||||
| impl DocumentsFields { | impl DocumentsFields { | ||||||
|     pub fn put_document_field( |     pub fn put_document_field( | ||||||
|         self, |         self, | ||||||
|         writer: &mut zlmdb::RwTxn, |         writer: &mut heed::RwTxn, | ||||||
|         document_id: DocumentId, |         document_id: DocumentId, | ||||||
|         attribute: SchemaAttr, |         attribute: SchemaAttr, | ||||||
|         value: &[u8], |         value: &[u8], | ||||||
| @@ -24,7 +24,7 @@ impl DocumentsFields { | |||||||
|  |  | ||||||
|     pub fn del_all_document_fields( |     pub fn del_all_document_fields( | ||||||
|         self, |         self, | ||||||
|         writer: &mut zlmdb::RwTxn, |         writer: &mut heed::RwTxn, | ||||||
|         document_id: DocumentId, |         document_id: DocumentId, | ||||||
|     ) -> ZResult<usize> { |     ) -> ZResult<usize> { | ||||||
|         let start = DocumentAttrKey::new(document_id, SchemaAttr::min()); |         let start = DocumentAttrKey::new(document_id, SchemaAttr::min()); | ||||||
| @@ -34,7 +34,7 @@ impl DocumentsFields { | |||||||
|  |  | ||||||
|     pub fn document_attribute<'txn>( |     pub fn document_attribute<'txn>( | ||||||
|         self, |         self, | ||||||
|         reader: &'txn zlmdb::RoTxn, |         reader: &'txn heed::RoTxn, | ||||||
|         document_id: DocumentId, |         document_id: DocumentId, | ||||||
|         attribute: SchemaAttr, |         attribute: SchemaAttr, | ||||||
|     ) -> ZResult<Option<&'txn [u8]>> { |     ) -> ZResult<Option<&'txn [u8]>> { | ||||||
| @@ -44,7 +44,7 @@ impl DocumentsFields { | |||||||
|  |  | ||||||
|     pub fn document_fields<'txn>( |     pub fn document_fields<'txn>( | ||||||
|         self, |         self, | ||||||
|         reader: &'txn zlmdb::RoTxn, |         reader: &'txn heed::RoTxn, | ||||||
|         document_id: DocumentId, |         document_id: DocumentId, | ||||||
|     ) -> ZResult<DocumentFieldsIter<'txn>> { |     ) -> ZResult<DocumentFieldsIter<'txn>> { | ||||||
|         let start = DocumentAttrKey::new(document_id, SchemaAttr::min()); |         let start = DocumentAttrKey::new(document_id, SchemaAttr::min()); | ||||||
| @@ -55,7 +55,7 @@ impl DocumentsFields { | |||||||
| } | } | ||||||
|  |  | ||||||
| pub struct DocumentFieldsIter<'txn> { | pub struct DocumentFieldsIter<'txn> { | ||||||
|     iter: zlmdb::RoRange<'txn, OwnedType<DocumentAttrKey>, ByteSlice>, |     iter: heed::RoRange<'txn, OwnedType<DocumentAttrKey>, ByteSlice>, | ||||||
| } | } | ||||||
|  |  | ||||||
| impl<'txn> Iterator for DocumentFieldsIter<'txn> { | impl<'txn> Iterator for DocumentFieldsIter<'txn> { | ||||||
|   | |||||||
| @@ -1,18 +1,18 @@ | |||||||
| use super::DocumentAttrKey; | use super::DocumentAttrKey; | ||||||
| use crate::DocumentId; | use crate::DocumentId; | ||||||
|  | use heed::types::OwnedType; | ||||||
|  | use heed::Result as ZResult; | ||||||
| use meilidb_schema::SchemaAttr; | use meilidb_schema::SchemaAttr; | ||||||
| use zlmdb::types::OwnedType; |  | ||||||
| use zlmdb::Result as ZResult; |  | ||||||
|  |  | ||||||
| #[derive(Copy, Clone)] | #[derive(Copy, Clone)] | ||||||
| pub struct DocumentsFieldsCounts { | pub struct DocumentsFieldsCounts { | ||||||
|     pub(crate) documents_fields_counts: zlmdb::Database<OwnedType<DocumentAttrKey>, OwnedType<u64>>, |     pub(crate) documents_fields_counts: heed::Database<OwnedType<DocumentAttrKey>, OwnedType<u64>>, | ||||||
| } | } | ||||||
|  |  | ||||||
| impl DocumentsFieldsCounts { | impl DocumentsFieldsCounts { | ||||||
|     pub fn put_document_field_count( |     pub fn put_document_field_count( | ||||||
|         self, |         self, | ||||||
|         writer: &mut zlmdb::RwTxn, |         writer: &mut heed::RwTxn, | ||||||
|         document_id: DocumentId, |         document_id: DocumentId, | ||||||
|         attribute: SchemaAttr, |         attribute: SchemaAttr, | ||||||
|         value: u64, |         value: u64, | ||||||
| @@ -23,7 +23,7 @@ impl DocumentsFieldsCounts { | |||||||
|  |  | ||||||
|     pub fn del_all_document_fields_counts( |     pub fn del_all_document_fields_counts( | ||||||
|         self, |         self, | ||||||
|         writer: &mut zlmdb::RwTxn, |         writer: &mut heed::RwTxn, | ||||||
|         document_id: DocumentId, |         document_id: DocumentId, | ||||||
|     ) -> ZResult<usize> { |     ) -> ZResult<usize> { | ||||||
|         let start = DocumentAttrKey::new(document_id, SchemaAttr::min()); |         let start = DocumentAttrKey::new(document_id, SchemaAttr::min()); | ||||||
| @@ -34,7 +34,7 @@ impl DocumentsFieldsCounts { | |||||||
|  |  | ||||||
|     pub fn document_field_count( |     pub fn document_field_count( | ||||||
|         self, |         self, | ||||||
|         reader: &zlmdb::RoTxn, |         reader: &heed::RoTxn, | ||||||
|         document_id: DocumentId, |         document_id: DocumentId, | ||||||
|         attribute: SchemaAttr, |         attribute: SchemaAttr, | ||||||
|     ) -> ZResult<Option<u64>> { |     ) -> ZResult<Option<u64>> { | ||||||
| @@ -47,7 +47,7 @@ impl DocumentsFieldsCounts { | |||||||
|  |  | ||||||
|     pub fn document_fields_counts<'txn>( |     pub fn document_fields_counts<'txn>( | ||||||
|         self, |         self, | ||||||
|         reader: &'txn zlmdb::RoTxn, |         reader: &'txn heed::RoTxn, | ||||||
|         document_id: DocumentId, |         document_id: DocumentId, | ||||||
|     ) -> ZResult<DocumentFieldsCountsIter<'txn>> { |     ) -> ZResult<DocumentFieldsCountsIter<'txn>> { | ||||||
|         let start = DocumentAttrKey::new(document_id, SchemaAttr::min()); |         let start = DocumentAttrKey::new(document_id, SchemaAttr::min()); | ||||||
| @@ -56,10 +56,7 @@ impl DocumentsFieldsCounts { | |||||||
|         Ok(DocumentFieldsCountsIter { iter }) |         Ok(DocumentFieldsCountsIter { iter }) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn documents_ids<'txn>( |     pub fn documents_ids<'txn>(self, reader: &'txn heed::RoTxn) -> ZResult<DocumentsIdsIter<'txn>> { | ||||||
|         self, |  | ||||||
|         reader: &'txn zlmdb::RoTxn, |  | ||||||
|     ) -> ZResult<DocumentsIdsIter<'txn>> { |  | ||||||
|         let iter = self.documents_fields_counts.iter(reader)?; |         let iter = self.documents_fields_counts.iter(reader)?; | ||||||
|         Ok(DocumentsIdsIter { |         Ok(DocumentsIdsIter { | ||||||
|             last_seen_id: None, |             last_seen_id: None, | ||||||
| @@ -69,7 +66,7 @@ impl DocumentsFieldsCounts { | |||||||
|  |  | ||||||
|     pub fn all_documents_fields_counts<'txn>( |     pub fn all_documents_fields_counts<'txn>( | ||||||
|         self, |         self, | ||||||
|         reader: &'txn zlmdb::RoTxn, |         reader: &'txn heed::RoTxn, | ||||||
|     ) -> ZResult<AllDocumentsFieldsCountsIter<'txn>> { |     ) -> ZResult<AllDocumentsFieldsCountsIter<'txn>> { | ||||||
|         let iter = self.documents_fields_counts.iter(reader)?; |         let iter = self.documents_fields_counts.iter(reader)?; | ||||||
|         Ok(AllDocumentsFieldsCountsIter { iter }) |         Ok(AllDocumentsFieldsCountsIter { iter }) | ||||||
| @@ -77,7 +74,7 @@ impl DocumentsFieldsCounts { | |||||||
| } | } | ||||||
|  |  | ||||||
| pub struct DocumentFieldsCountsIter<'txn> { | pub struct DocumentFieldsCountsIter<'txn> { | ||||||
|     iter: zlmdb::RoRange<'txn, OwnedType<DocumentAttrKey>, OwnedType<u64>>, |     iter: heed::RoRange<'txn, OwnedType<DocumentAttrKey>, OwnedType<u64>>, | ||||||
| } | } | ||||||
|  |  | ||||||
| impl Iterator for DocumentFieldsCountsIter<'_> { | impl Iterator for DocumentFieldsCountsIter<'_> { | ||||||
| @@ -97,7 +94,7 @@ impl Iterator for DocumentFieldsCountsIter<'_> { | |||||||
|  |  | ||||||
| pub struct DocumentsIdsIter<'txn> { | pub struct DocumentsIdsIter<'txn> { | ||||||
|     last_seen_id: Option<DocumentId>, |     last_seen_id: Option<DocumentId>, | ||||||
|     iter: zlmdb::RoIter<'txn, OwnedType<DocumentAttrKey>, OwnedType<u64>>, |     iter: heed::RoIter<'txn, OwnedType<DocumentAttrKey>, OwnedType<u64>>, | ||||||
| } | } | ||||||
|  |  | ||||||
| impl Iterator for DocumentsIdsIter<'_> { | impl Iterator for DocumentsIdsIter<'_> { | ||||||
| @@ -121,7 +118,7 @@ impl Iterator for DocumentsIdsIter<'_> { | |||||||
| } | } | ||||||
|  |  | ||||||
| pub struct AllDocumentsFieldsCountsIter<'txn> { | pub struct AllDocumentsFieldsCountsIter<'txn> { | ||||||
|     iter: zlmdb::RoIter<'txn, OwnedType<DocumentAttrKey>, OwnedType<u64>>, |     iter: heed::RoIter<'txn, OwnedType<DocumentAttrKey>, OwnedType<u64>>, | ||||||
| } | } | ||||||
|  |  | ||||||
| impl<'r> Iterator for AllDocumentsFieldsCountsIter<'r> { | impl<'r> Iterator for AllDocumentsFieldsCountsIter<'r> { | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| use crate::RankedMap; | use crate::RankedMap; | ||||||
|  | use heed::types::{ByteSlice, OwnedType, SerdeBincode, Str}; | ||||||
|  | use heed::Result as ZResult; | ||||||
| use meilidb_schema::Schema; | use meilidb_schema::Schema; | ||||||
| use std::sync::Arc; | use std::sync::Arc; | ||||||
| use zlmdb::types::{ByteSlice, OwnedType, Serde, Str}; |  | ||||||
| use zlmdb::Result as ZResult; |  | ||||||
|  |  | ||||||
| const CUSTOMS_KEY: &str = "customs-key"; | const CUSTOMS_KEY: &str = "customs-key"; | ||||||
| const NUMBER_OF_DOCUMENTS_KEY: &str = "number-of-documents"; | const NUMBER_OF_DOCUMENTS_KEY: &str = "number-of-documents"; | ||||||
| @@ -13,16 +13,16 @@ const WORDS_KEY: &str = "words"; | |||||||
|  |  | ||||||
| #[derive(Copy, Clone)] | #[derive(Copy, Clone)] | ||||||
| pub struct Main { | pub struct Main { | ||||||
|     pub(crate) main: zlmdb::DynDatabase, |     pub(crate) main: heed::PolyDatabase, | ||||||
| } | } | ||||||
|  |  | ||||||
| impl Main { | impl Main { | ||||||
|     pub fn put_words_fst(self, writer: &mut zlmdb::RwTxn, fst: &fst::Set) -> ZResult<()> { |     pub fn put_words_fst(self, writer: &mut heed::RwTxn, fst: &fst::Set) -> ZResult<()> { | ||||||
|         let bytes = fst.as_fst().as_bytes(); |         let bytes = fst.as_fst().as_bytes(); | ||||||
|         self.main.put::<Str, ByteSlice>(writer, WORDS_KEY, bytes) |         self.main.put::<Str, ByteSlice>(writer, WORDS_KEY, bytes) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn words_fst(self, reader: &zlmdb::RoTxn) -> ZResult<Option<fst::Set>> { |     pub fn words_fst(self, reader: &heed::RoTxn) -> ZResult<Option<fst::Set>> { | ||||||
|         match self.main.get::<Str, ByteSlice>(reader, WORDS_KEY)? { |         match self.main.get::<Str, ByteSlice>(reader, WORDS_KEY)? { | ||||||
|             Some(bytes) => { |             Some(bytes) => { | ||||||
|                 let len = bytes.len(); |                 let len = bytes.len(); | ||||||
| @@ -34,31 +34,32 @@ impl Main { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn put_schema(self, writer: &mut zlmdb::RwTxn, schema: &Schema) -> ZResult<()> { |     pub fn put_schema(self, writer: &mut heed::RwTxn, schema: &Schema) -> ZResult<()> { | ||||||
|         self.main |         self.main | ||||||
|             .put::<Str, Serde<Schema>>(writer, SCHEMA_KEY, schema) |             .put::<Str, SerdeBincode<Schema>>(writer, SCHEMA_KEY, schema) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn schema(self, reader: &zlmdb::RoTxn) -> ZResult<Option<Schema>> { |     pub fn schema(self, reader: &heed::RoTxn) -> ZResult<Option<Schema>> { | ||||||
|         self.main.get::<Str, Serde<Schema>>(reader, SCHEMA_KEY) |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     pub fn put_ranked_map(self, writer: &mut zlmdb::RwTxn, ranked_map: &RankedMap) -> ZResult<()> { |  | ||||||
|         self.main |         self.main | ||||||
|             .put::<Str, Serde<RankedMap>>(writer, RANKED_MAP_KEY, &ranked_map) |             .get::<Str, SerdeBincode<Schema>>(reader, SCHEMA_KEY) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn ranked_map(self, reader: &zlmdb::RoTxn) -> ZResult<Option<RankedMap>> { |     pub fn put_ranked_map(self, writer: &mut heed::RwTxn, ranked_map: &RankedMap) -> ZResult<()> { | ||||||
|         self.main |         self.main | ||||||
|             .get::<Str, Serde<RankedMap>>(reader, RANKED_MAP_KEY) |             .put::<Str, SerdeBincode<RankedMap>>(writer, RANKED_MAP_KEY, &ranked_map) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn put_synonyms_fst(self, writer: &mut zlmdb::RwTxn, fst: &fst::Set) -> ZResult<()> { |     pub fn ranked_map(self, reader: &heed::RoTxn) -> ZResult<Option<RankedMap>> { | ||||||
|  |         self.main | ||||||
|  |             .get::<Str, SerdeBincode<RankedMap>>(reader, RANKED_MAP_KEY) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     pub fn put_synonyms_fst(self, writer: &mut heed::RwTxn, fst: &fst::Set) -> ZResult<()> { | ||||||
|         let bytes = fst.as_fst().as_bytes(); |         let bytes = fst.as_fst().as_bytes(); | ||||||
|         self.main.put::<Str, ByteSlice>(writer, SYNONYMS_KEY, bytes) |         self.main.put::<Str, ByteSlice>(writer, SYNONYMS_KEY, bytes) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn synonyms_fst(self, reader: &zlmdb::RoTxn) -> ZResult<Option<fst::Set>> { |     pub fn synonyms_fst(self, reader: &heed::RoTxn) -> ZResult<Option<fst::Set>> { | ||||||
|         match self.main.get::<Str, ByteSlice>(reader, SYNONYMS_KEY)? { |         match self.main.get::<Str, ByteSlice>(reader, SYNONYMS_KEY)? { | ||||||
|             Some(bytes) => { |             Some(bytes) => { | ||||||
|                 let len = bytes.len(); |                 let len = bytes.len(); | ||||||
| @@ -70,7 +71,7 @@ impl Main { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn put_number_of_documents<F>(self, writer: &mut zlmdb::RwTxn, f: F) -> ZResult<u64> |     pub fn put_number_of_documents<F>(self, writer: &mut heed::RwTxn, f: F) -> ZResult<u64> | ||||||
|     where |     where | ||||||
|         F: Fn(u64) -> u64, |         F: Fn(u64) -> u64, | ||||||
|     { |     { | ||||||
| @@ -80,7 +81,7 @@ impl Main { | |||||||
|         Ok(new) |         Ok(new) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn number_of_documents(self, reader: &zlmdb::RoTxn) -> ZResult<u64> { |     pub fn number_of_documents(self, reader: &heed::RoTxn) -> ZResult<u64> { | ||||||
|         match self |         match self | ||||||
|             .main |             .main | ||||||
|             .get::<Str, OwnedType<u64>>(reader, NUMBER_OF_DOCUMENTS_KEY)? |             .get::<Str, OwnedType<u64>>(reader, NUMBER_OF_DOCUMENTS_KEY)? | ||||||
| @@ -90,12 +91,12 @@ impl Main { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn put_customs(self, writer: &mut zlmdb::RwTxn, customs: &[u8]) -> ZResult<()> { |     pub fn put_customs(self, writer: &mut heed::RwTxn, customs: &[u8]) -> ZResult<()> { | ||||||
|         self.main |         self.main | ||||||
|             .put::<Str, ByteSlice>(writer, CUSTOMS_KEY, customs) |             .put::<Str, ByteSlice>(writer, CUSTOMS_KEY, customs) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn customs<'txn>(self, reader: &'txn zlmdb::RoTxn) -> ZResult<Option<&'txn [u8]>> { |     pub fn customs<'txn>(self, reader: &'txn heed::RoTxn) -> ZResult<Option<&'txn [u8]>> { | ||||||
|         self.main.get::<Str, ByteSlice>(reader, CUSTOMS_KEY) |         self.main.get::<Str, ByteSlice>(reader, CUSTOMS_KEY) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -20,10 +20,10 @@ pub use self::updates_results::UpdatesResults; | |||||||
|  |  | ||||||
| use std::collections::HashSet; | use std::collections::HashSet; | ||||||
|  |  | ||||||
|  | use heed::Result as ZResult; | ||||||
| use meilidb_schema::{Schema, SchemaAttr}; | use meilidb_schema::{Schema, SchemaAttr}; | ||||||
| use serde::de; | use serde::de; | ||||||
| use zerocopy::{AsBytes, FromBytes}; | use zerocopy::{AsBytes, FromBytes}; | ||||||
| use zlmdb::Result as ZResult; |  | ||||||
|  |  | ||||||
| use crate::criterion::Criteria; | use crate::criterion::Criteria; | ||||||
| use crate::serde::Deserializer; | use crate::serde::Deserializer; | ||||||
| @@ -97,7 +97,7 @@ pub struct Index { | |||||||
| impl Index { | impl Index { | ||||||
|     pub fn document<T: de::DeserializeOwned>( |     pub fn document<T: de::DeserializeOwned>( | ||||||
|         &self, |         &self, | ||||||
|         reader: &zlmdb::RoTxn, |         reader: &heed::RoTxn, | ||||||
|         attributes: Option<&HashSet<&str>>, |         attributes: Option<&HashSet<&str>>, | ||||||
|         document_id: DocumentId, |         document_id: DocumentId, | ||||||
|     ) -> MResult<Option<T>> { |     ) -> MResult<Option<T>> { | ||||||
| @@ -127,7 +127,7 @@ impl Index { | |||||||
|  |  | ||||||
|     pub fn document_attribute<T: de::DeserializeOwned>( |     pub fn document_attribute<T: de::DeserializeOwned>( | ||||||
|         &self, |         &self, | ||||||
|         reader: &zlmdb::RoTxn, |         reader: &heed::RoTxn, | ||||||
|         document_id: DocumentId, |         document_id: DocumentId, | ||||||
|         attribute: SchemaAttr, |         attribute: SchemaAttr, | ||||||
|     ) -> MResult<Option<T>> { |     ) -> MResult<Option<T>> { | ||||||
| @@ -140,12 +140,12 @@ impl Index { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn schema_update(&self, writer: &mut zlmdb::RwTxn, schema: Schema) -> MResult<u64> { |     pub fn schema_update(&self, writer: &mut heed::RwTxn, schema: Schema) -> MResult<u64> { | ||||||
|         let _ = self.updates_notifier.send(()); |         let _ = self.updates_notifier.send(()); | ||||||
|         update::push_schema_update(writer, self.updates, self.updates_results, schema) |         update::push_schema_update(writer, self.updates, self.updates_results, schema) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn customs_update(&self, writer: &mut zlmdb::RwTxn, customs: Vec<u8>) -> ZResult<u64> { |     pub fn customs_update(&self, writer: &mut heed::RwTxn, customs: Vec<u8>) -> ZResult<u64> { | ||||||
|         let _ = self.updates_notifier.send(()); |         let _ = self.updates_notifier.send(()); | ||||||
|         update::push_customs_update(writer, self.updates, self.updates_results, customs) |         update::push_customs_update(writer, self.updates, self.updates_results, customs) | ||||||
|     } |     } | ||||||
| @@ -182,7 +182,7 @@ impl Index { | |||||||
|         ) |         ) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn current_update_id(&self, reader: &zlmdb::RoTxn) -> MResult<Option<u64>> { |     pub fn current_update_id(&self, reader: &heed::RoTxn) -> MResult<Option<u64>> { | ||||||
|         match self.updates.last_update_id(reader)? { |         match self.updates.last_update_id(reader)? { | ||||||
|             Some((id, _)) => Ok(Some(id)), |             Some((id, _)) => Ok(Some(id)), | ||||||
|             None => Ok(None), |             None => Ok(None), | ||||||
| @@ -191,7 +191,7 @@ impl Index { | |||||||
|  |  | ||||||
|     pub fn update_status( |     pub fn update_status( | ||||||
|         &self, |         &self, | ||||||
|         reader: &zlmdb::RoTxn, |         reader: &heed::RoTxn, | ||||||
|         update_id: u64, |         update_id: u64, | ||||||
|     ) -> MResult<update::UpdateStatus> { |     ) -> MResult<update::UpdateStatus> { | ||||||
|         update::update_status(reader, self.updates, self.updates_results, update_id) |         update::update_status(reader, self.updates, self.updates_results, update_id) | ||||||
| @@ -221,7 +221,7 @@ impl Index { | |||||||
| } | } | ||||||
|  |  | ||||||
| pub fn create( | pub fn create( | ||||||
|     env: &zlmdb::Env, |     env: &heed::Env, | ||||||
|     name: &str, |     name: &str, | ||||||
|     updates_notifier: crossbeam_channel::Sender<()>, |     updates_notifier: crossbeam_channel::Sender<()>, | ||||||
| ) -> MResult<Index> { | ) -> MResult<Index> { | ||||||
| @@ -261,7 +261,7 @@ pub fn create( | |||||||
| } | } | ||||||
|  |  | ||||||
| pub fn open( | pub fn open( | ||||||
|     env: &zlmdb::Env, |     env: &heed::Env, | ||||||
|     name: &str, |     name: &str, | ||||||
|     updates_notifier: crossbeam_channel::Sender<()>, |     updates_notifier: crossbeam_channel::Sender<()>, | ||||||
| ) -> MResult<Option<Index>> { | ) -> MResult<Option<Index>> { | ||||||
|   | |||||||
| @@ -1,31 +1,31 @@ | |||||||
| use crate::DocIndex; | use crate::DocIndex; | ||||||
|  | use heed::types::{ByteSlice, CowSlice}; | ||||||
|  | use heed::Result as ZResult; | ||||||
| use sdset::{Set, SetBuf}; | use sdset::{Set, SetBuf}; | ||||||
| use std::borrow::Cow; | use std::borrow::Cow; | ||||||
| use zlmdb::types::{ByteSlice, CowSlice}; |  | ||||||
| use zlmdb::Result as ZResult; |  | ||||||
|  |  | ||||||
| #[derive(Copy, Clone)] | #[derive(Copy, Clone)] | ||||||
| pub struct PostingsLists { | pub struct PostingsLists { | ||||||
|     pub(crate) postings_lists: zlmdb::Database<ByteSlice, CowSlice<DocIndex>>, |     pub(crate) postings_lists: heed::Database<ByteSlice, CowSlice<DocIndex>>, | ||||||
| } | } | ||||||
|  |  | ||||||
| impl PostingsLists { | impl PostingsLists { | ||||||
|     pub fn put_postings_list( |     pub fn put_postings_list( | ||||||
|         self, |         self, | ||||||
|         writer: &mut zlmdb::RwTxn, |         writer: &mut heed::RwTxn, | ||||||
|         word: &[u8], |         word: &[u8], | ||||||
|         words_indexes: &Set<DocIndex>, |         words_indexes: &Set<DocIndex>, | ||||||
|     ) -> ZResult<()> { |     ) -> ZResult<()> { | ||||||
|         self.postings_lists.put(writer, word, words_indexes) |         self.postings_lists.put(writer, word, words_indexes) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn del_postings_list(self, writer: &mut zlmdb::RwTxn, word: &[u8]) -> ZResult<bool> { |     pub fn del_postings_list(self, writer: &mut heed::RwTxn, word: &[u8]) -> ZResult<bool> { | ||||||
|         self.postings_lists.delete(writer, word) |         self.postings_lists.delete(writer, word) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn postings_list<'txn>( |     pub fn postings_list<'txn>( | ||||||
|         self, |         self, | ||||||
|         reader: &'txn zlmdb::RoTxn, |         reader: &'txn heed::RoTxn, | ||||||
|         word: &[u8], |         word: &[u8], | ||||||
|     ) -> ZResult<Option<Cow<'txn, Set<DocIndex>>>> { |     ) -> ZResult<Option<Cow<'txn, Set<DocIndex>>>> { | ||||||
|         match self.postings_lists.get(reader, word)? { |         match self.postings_lists.get(reader, word)? { | ||||||
|   | |||||||
| @@ -1,16 +1,16 @@ | |||||||
|  | use heed::types::ByteSlice; | ||||||
|  | use heed::Result as ZResult; | ||||||
| use std::sync::Arc; | use std::sync::Arc; | ||||||
| use zlmdb::types::ByteSlice; |  | ||||||
| use zlmdb::Result as ZResult; |  | ||||||
|  |  | ||||||
| #[derive(Copy, Clone)] | #[derive(Copy, Clone)] | ||||||
| pub struct Synonyms { | pub struct Synonyms { | ||||||
|     pub(crate) synonyms: zlmdb::Database<ByteSlice, ByteSlice>, |     pub(crate) synonyms: heed::Database<ByteSlice, ByteSlice>, | ||||||
| } | } | ||||||
|  |  | ||||||
| impl Synonyms { | impl Synonyms { | ||||||
|     pub fn put_synonyms( |     pub fn put_synonyms( | ||||||
|         self, |         self, | ||||||
|         writer: &mut zlmdb::RwTxn, |         writer: &mut heed::RwTxn, | ||||||
|         word: &[u8], |         word: &[u8], | ||||||
|         synonyms: &fst::Set, |         synonyms: &fst::Set, | ||||||
|     ) -> ZResult<()> { |     ) -> ZResult<()> { | ||||||
| @@ -18,11 +18,11 @@ impl Synonyms { | |||||||
|         self.synonyms.put(writer, word, bytes) |         self.synonyms.put(writer, word, bytes) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn del_synonyms(self, writer: &mut zlmdb::RwTxn, word: &[u8]) -> ZResult<bool> { |     pub fn del_synonyms(self, writer: &mut heed::RwTxn, word: &[u8]) -> ZResult<bool> { | ||||||
|         self.synonyms.delete(writer, word) |         self.synonyms.delete(writer, word) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn synonyms(self, reader: &zlmdb::RoTxn, word: &[u8]) -> ZResult<Option<fst::Set>> { |     pub fn synonyms(self, reader: &heed::RoTxn, word: &[u8]) -> ZResult<Option<fst::Set>> { | ||||||
|         match self.synonyms.get(reader, word)? { |         match self.synonyms.get(reader, word)? { | ||||||
|             Some(bytes) => { |             Some(bytes) => { | ||||||
|                 let len = bytes.len(); |                 let len = bytes.len(); | ||||||
|   | |||||||
| @@ -1,42 +1,16 @@ | |||||||
| use super::BEU64; | use super::BEU64; | ||||||
| use crate::update::Update; | use crate::update::Update; | ||||||
| use serde::{Deserialize, Serialize}; | use heed::types::{OwnedType, SerdeJson}; | ||||||
| use std::borrow::Cow; | use heed::Result as ZResult; | ||||||
| use zlmdb::types::OwnedType; |  | ||||||
| use zlmdb::{BytesDecode, BytesEncode, Result as ZResult}; |  | ||||||
|  |  | ||||||
| pub struct SerdeJson<T>(std::marker::PhantomData<T>); |  | ||||||
|  |  | ||||||
| impl<T> BytesEncode for SerdeJson<T> |  | ||||||
| where |  | ||||||
|     T: Serialize, |  | ||||||
| { |  | ||||||
|     type EItem = T; |  | ||||||
|  |  | ||||||
|     fn bytes_encode(item: &Self::EItem) -> Option<Cow<[u8]>> { |  | ||||||
|         serde_json::to_vec(item).map(Cow::Owned).ok() |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| impl<'a, T: 'a> BytesDecode<'a> for SerdeJson<T> |  | ||||||
| where |  | ||||||
|     T: Deserialize<'a> + Clone, |  | ||||||
| { |  | ||||||
|     type DItem = T; |  | ||||||
|  |  | ||||||
|     fn bytes_decode(bytes: &'a [u8]) -> Option<Self::DItem> { |  | ||||||
|         serde_json::from_slice(bytes).ok() |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #[derive(Copy, Clone)] | #[derive(Copy, Clone)] | ||||||
| pub struct Updates { | pub struct Updates { | ||||||
|     pub(crate) updates: zlmdb::Database<OwnedType<BEU64>, SerdeJson<Update>>, |     pub(crate) updates: heed::Database<OwnedType<BEU64>, SerdeJson<Update>>, | ||||||
| } | } | ||||||
|  |  | ||||||
| impl Updates { | impl Updates { | ||||||
|     // TODO do not trigger deserialize if possible |     // TODO do not trigger deserialize if possible | ||||||
|     pub fn last_update_id(self, reader: &zlmdb::RoTxn) -> ZResult<Option<(u64, Update)>> { |     pub fn last_update_id(self, reader: &heed::RoTxn) -> ZResult<Option<(u64, Update)>> { | ||||||
|         match self.updates.last(reader)? { |         match self.updates.last(reader)? { | ||||||
|             Some((key, data)) => Ok(Some((key.get(), data))), |             Some((key, data)) => Ok(Some((key.get(), data))), | ||||||
|             None => Ok(None), |             None => Ok(None), | ||||||
| @@ -44,7 +18,7 @@ impl Updates { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     // TODO do not trigger deserialize if possible |     // TODO do not trigger deserialize if possible | ||||||
|     fn first_update_id(self, reader: &zlmdb::RoTxn) -> ZResult<Option<(u64, Update)>> { |     fn first_update_id(self, reader: &heed::RoTxn) -> ZResult<Option<(u64, Update)>> { | ||||||
|         match self.updates.first(reader)? { |         match self.updates.first(reader)? { | ||||||
|             Some((key, data)) => Ok(Some((key.get(), data))), |             Some((key, data)) => Ok(Some((key.get(), data))), | ||||||
|             None => Ok(None), |             None => Ok(None), | ||||||
| @@ -52,14 +26,14 @@ impl Updates { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     // TODO do not trigger deserialize if possible |     // TODO do not trigger deserialize if possible | ||||||
|     pub fn contains(self, reader: &zlmdb::RoTxn, update_id: u64) -> ZResult<bool> { |     pub fn contains(self, reader: &heed::RoTxn, update_id: u64) -> ZResult<bool> { | ||||||
|         let update_id = BEU64::new(update_id); |         let update_id = BEU64::new(update_id); | ||||||
|         self.updates.get(reader, &update_id).map(|v| v.is_some()) |         self.updates.get(reader, &update_id).map(|v| v.is_some()) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn put_update( |     pub fn put_update( | ||||||
|         self, |         self, | ||||||
|         writer: &mut zlmdb::RwTxn, |         writer: &mut heed::RwTxn, | ||||||
|         update_id: u64, |         update_id: u64, | ||||||
|         update: &Update, |         update: &Update, | ||||||
|     ) -> ZResult<()> { |     ) -> ZResult<()> { | ||||||
| @@ -68,7 +42,7 @@ impl Updates { | |||||||
|         self.updates.put(writer, &update_id, update) |         self.updates.put(writer, &update_id, update) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn pop_front(self, writer: &mut zlmdb::RwTxn) -> ZResult<Option<(u64, Update)>> { |     pub fn pop_front(self, writer: &mut heed::RwTxn) -> ZResult<Option<(u64, Update)>> { | ||||||
|         match self.first_update_id(writer)? { |         match self.first_update_id(writer)? { | ||||||
|             Some((update_id, update)) => { |             Some((update_id, update)) => { | ||||||
|                 let key = BEU64::new(update_id); |                 let key = BEU64::new(update_id); | ||||||
|   | |||||||
| @@ -1,15 +1,15 @@ | |||||||
| use super::BEU64; | use super::BEU64; | ||||||
| use crate::update::UpdateResult; | use crate::update::UpdateResult; | ||||||
| use zlmdb::types::{OwnedType, Serde}; | use heed::types::{OwnedType, SerdeBincode}; | ||||||
| use zlmdb::Result as ZResult; | use heed::Result as ZResult; | ||||||
|  |  | ||||||
| #[derive(Copy, Clone)] | #[derive(Copy, Clone)] | ||||||
| pub struct UpdatesResults { | pub struct UpdatesResults { | ||||||
|     pub(crate) updates_results: zlmdb::Database<OwnedType<BEU64>, Serde<UpdateResult>>, |     pub(crate) updates_results: heed::Database<OwnedType<BEU64>, SerdeBincode<UpdateResult>>, | ||||||
| } | } | ||||||
|  |  | ||||||
| impl UpdatesResults { | impl UpdatesResults { | ||||||
|     pub fn last_update_id(self, reader: &zlmdb::RoTxn) -> ZResult<Option<(u64, UpdateResult)>> { |     pub fn last_update_id(self, reader: &heed::RoTxn) -> ZResult<Option<(u64, UpdateResult)>> { | ||||||
|         match self.updates_results.last(reader)? { |         match self.updates_results.last(reader)? { | ||||||
|             Some((key, data)) => Ok(Some((key.get(), data))), |             Some((key, data)) => Ok(Some((key.get(), data))), | ||||||
|             None => Ok(None), |             None => Ok(None), | ||||||
| @@ -18,7 +18,7 @@ impl UpdatesResults { | |||||||
|  |  | ||||||
|     pub fn put_update_result( |     pub fn put_update_result( | ||||||
|         self, |         self, | ||||||
|         writer: &mut zlmdb::RwTxn, |         writer: &mut heed::RwTxn, | ||||||
|         update_id: u64, |         update_id: u64, | ||||||
|         update_result: &UpdateResult, |         update_result: &UpdateResult, | ||||||
|     ) -> ZResult<()> { |     ) -> ZResult<()> { | ||||||
| @@ -28,7 +28,7 @@ impl UpdatesResults { | |||||||
|  |  | ||||||
|     pub fn update_result( |     pub fn update_result( | ||||||
|         self, |         self, | ||||||
|         reader: &zlmdb::RoTxn, |         reader: &heed::RoTxn, | ||||||
|         update_id: u64, |         update_id: u64, | ||||||
|     ) -> ZResult<Option<UpdateResult>> { |     ) -> ZResult<Option<UpdateResult>> { | ||||||
|         let update_id = BEU64::new(update_id); |         let update_id = BEU64::new(update_id); | ||||||
|   | |||||||
| @@ -1,9 +1,9 @@ | |||||||
| use crate::store; | use crate::store; | ||||||
| use crate::update::{next_update_id, Update}; | use crate::update::{next_update_id, Update}; | ||||||
| use zlmdb::Result as ZResult; | use heed::Result as ZResult; | ||||||
|  |  | ||||||
| pub fn apply_customs_update( | pub fn apply_customs_update( | ||||||
|     writer: &mut zlmdb::RwTxn, |     writer: &mut heed::RwTxn, | ||||||
|     main_store: store::Main, |     main_store: store::Main, | ||||||
|     customs: &[u8], |     customs: &[u8], | ||||||
| ) -> ZResult<()> { | ) -> ZResult<()> { | ||||||
| @@ -11,7 +11,7 @@ pub fn apply_customs_update( | |||||||
| } | } | ||||||
|  |  | ||||||
| pub fn push_customs_update( | pub fn push_customs_update( | ||||||
|     writer: &mut zlmdb::RwTxn, |     writer: &mut heed::RwTxn, | ||||||
|     updates_store: store::Updates, |     updates_store: store::Updates, | ||||||
|     updates_results_store: store::UpdatesResults, |     updates_results_store: store::UpdatesResults, | ||||||
|     customs: Vec<u8>, |     customs: Vec<u8>, | ||||||
|   | |||||||
| @@ -35,7 +35,7 @@ impl<D> DocumentsAddition<D> { | |||||||
|         self.documents.push(document); |         self.documents.push(document); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn finalize(self, writer: &mut zlmdb::RwTxn) -> MResult<u64> |     pub fn finalize(self, writer: &mut heed::RwTxn) -> MResult<u64> | ||||||
|     where |     where | ||||||
|         D: serde::Serialize, |         D: serde::Serialize, | ||||||
|     { |     { | ||||||
| @@ -57,7 +57,7 @@ impl<D> Extend<D> for DocumentsAddition<D> { | |||||||
| } | } | ||||||
|  |  | ||||||
| pub fn push_documents_addition<D: serde::Serialize>( | pub fn push_documents_addition<D: serde::Serialize>( | ||||||
|     writer: &mut zlmdb::RwTxn, |     writer: &mut heed::RwTxn, | ||||||
|     updates_store: store::Updates, |     updates_store: store::Updates, | ||||||
|     updates_results_store: store::UpdatesResults, |     updates_results_store: store::UpdatesResults, | ||||||
|     addition: Vec<D>, |     addition: Vec<D>, | ||||||
| @@ -78,7 +78,7 @@ pub fn push_documents_addition<D: serde::Serialize>( | |||||||
| } | } | ||||||
|  |  | ||||||
| pub fn apply_documents_addition( | pub fn apply_documents_addition( | ||||||
|     writer: &mut zlmdb::RwTxn, |     writer: &mut heed::RwTxn, | ||||||
|     main_store: store::Main, |     main_store: store::Main, | ||||||
|     documents_fields_store: store::DocumentsFields, |     documents_fields_store: store::DocumentsFields, | ||||||
|     documents_fields_counts_store: store::DocumentsFieldsCounts, |     documents_fields_counts_store: store::DocumentsFieldsCounts, | ||||||
|   | |||||||
| @@ -49,7 +49,7 @@ impl DocumentsDeletion { | |||||||
|         Ok(()) |         Ok(()) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn finalize(self, writer: &mut zlmdb::RwTxn) -> MResult<u64> { |     pub fn finalize(self, writer: &mut heed::RwTxn) -> MResult<u64> { | ||||||
|         let _ = self.updates_notifier.send(()); |         let _ = self.updates_notifier.send(()); | ||||||
|         let update_id = push_documents_deletion( |         let update_id = push_documents_deletion( | ||||||
|             writer, |             writer, | ||||||
| @@ -68,7 +68,7 @@ impl Extend<DocumentId> for DocumentsDeletion { | |||||||
| } | } | ||||||
|  |  | ||||||
| pub fn push_documents_deletion( | pub fn push_documents_deletion( | ||||||
|     writer: &mut zlmdb::RwTxn, |     writer: &mut heed::RwTxn, | ||||||
|     updates_store: store::Updates, |     updates_store: store::Updates, | ||||||
|     updates_results_store: store::UpdatesResults, |     updates_results_store: store::UpdatesResults, | ||||||
|     deletion: Vec<DocumentId>, |     deletion: Vec<DocumentId>, | ||||||
| @@ -82,7 +82,7 @@ pub fn push_documents_deletion( | |||||||
| } | } | ||||||
|  |  | ||||||
| pub fn apply_documents_deletion( | pub fn apply_documents_deletion( | ||||||
|     writer: &mut zlmdb::RwTxn, |     writer: &mut heed::RwTxn, | ||||||
|     main_store: store::Main, |     main_store: store::Main, | ||||||
|     documents_fields_store: store::DocumentsFields, |     documents_fields_store: store::DocumentsFields, | ||||||
|     documents_fields_counts_store: store::DocumentsFieldsCounts, |     documents_fields_counts_store: store::DocumentsFieldsCounts, | ||||||
|   | |||||||
| @@ -16,9 +16,9 @@ use std::cmp; | |||||||
| use std::collections::BTreeMap; | use std::collections::BTreeMap; | ||||||
| use std::time::{Duration, Instant}; | use std::time::{Duration, Instant}; | ||||||
|  |  | ||||||
|  | use heed::Result as ZResult; | ||||||
| use log::debug; | use log::debug; | ||||||
| use serde::{Deserialize, Serialize}; | use serde::{Deserialize, Serialize}; | ||||||
| use zlmdb::Result as ZResult; |  | ||||||
|  |  | ||||||
| use crate::{store, DocumentId, MResult, RankedMap}; | use crate::{store, DocumentId, MResult, RankedMap}; | ||||||
| use meilidb_schema::Schema; | use meilidb_schema::Schema; | ||||||
| @@ -64,7 +64,7 @@ pub enum UpdateStatus { | |||||||
| } | } | ||||||
|  |  | ||||||
| pub fn update_status( | pub fn update_status( | ||||||
|     reader: &zlmdb::RoTxn, |     reader: &heed::RoTxn, | ||||||
|     updates_store: store::Updates, |     updates_store: store::Updates, | ||||||
|     updates_results_store: store::UpdatesResults, |     updates_results_store: store::UpdatesResults, | ||||||
|     update_id: u64, |     update_id: u64, | ||||||
| @@ -82,7 +82,7 @@ pub fn update_status( | |||||||
| } | } | ||||||
|  |  | ||||||
| pub fn next_update_id( | pub fn next_update_id( | ||||||
|     writer: &mut zlmdb::RwTxn, |     writer: &mut heed::RwTxn, | ||||||
|     updates_store: store::Updates, |     updates_store: store::Updates, | ||||||
|     updates_results_store: store::UpdatesResults, |     updates_results_store: store::UpdatesResults, | ||||||
| ) -> ZResult<u64> { | ) -> ZResult<u64> { | ||||||
| @@ -98,10 +98,7 @@ pub fn next_update_id( | |||||||
|     Ok(new_update_id) |     Ok(new_update_id) | ||||||
| } | } | ||||||
|  |  | ||||||
| pub fn update_task( | pub fn update_task(writer: &mut heed::RwTxn, index: store::Index) -> MResult<Option<UpdateResult>> { | ||||||
|     writer: &mut zlmdb::RwTxn, |  | ||||||
|     index: store::Index, |  | ||||||
| ) -> MResult<Option<UpdateResult>> { |  | ||||||
|     let (update_id, update) = match index.updates.pop_front(writer)? { |     let (update_id, update) = match index.updates.pop_front(writer)? { | ||||||
|         Some(value) => value, |         Some(value) => value, | ||||||
|         None => return Ok(None), |         None => return Ok(None), | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ use crate::{error::UnsupportedOperation, store, MResult}; | |||||||
| use meilidb_schema::Schema; | use meilidb_schema::Schema; | ||||||
|  |  | ||||||
| pub fn apply_schema_update( | pub fn apply_schema_update( | ||||||
|     writer: &mut zlmdb::RwTxn, |     writer: &mut heed::RwTxn, | ||||||
|     main_store: store::Main, |     main_store: store::Main, | ||||||
|     new_schema: &Schema, |     new_schema: &Schema, | ||||||
| ) -> MResult<()> { | ) -> MResult<()> { | ||||||
| @@ -17,7 +17,7 @@ pub fn apply_schema_update( | |||||||
| } | } | ||||||
|  |  | ||||||
| pub fn push_schema_update( | pub fn push_schema_update( | ||||||
|     writer: &mut zlmdb::RwTxn, |     writer: &mut heed::RwTxn, | ||||||
|     updates_store: store::Updates, |     updates_store: store::Updates, | ||||||
|     updates_results_store: store::UpdatesResults, |     updates_results_store: store::UpdatesResults, | ||||||
|     schema: Schema, |     schema: Schema, | ||||||
|   | |||||||
| @@ -42,7 +42,7 @@ impl SynonymsAddition { | |||||||
|             .extend(alternatives); |             .extend(alternatives); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn finalize(self, writer: &mut zlmdb::RwTxn) -> MResult<u64> { |     pub fn finalize(self, writer: &mut heed::RwTxn) -> MResult<u64> { | ||||||
|         let _ = self.updates_notifier.send(()); |         let _ = self.updates_notifier.send(()); | ||||||
|         let update_id = push_synonyms_addition( |         let update_id = push_synonyms_addition( | ||||||
|             writer, |             writer, | ||||||
| @@ -55,7 +55,7 @@ impl SynonymsAddition { | |||||||
| } | } | ||||||
|  |  | ||||||
| pub fn push_synonyms_addition( | pub fn push_synonyms_addition( | ||||||
|     writer: &mut zlmdb::RwTxn, |     writer: &mut heed::RwTxn, | ||||||
|     updates_store: store::Updates, |     updates_store: store::Updates, | ||||||
|     updates_results_store: store::UpdatesResults, |     updates_results_store: store::UpdatesResults, | ||||||
|     addition: BTreeMap<String, Vec<String>>, |     addition: BTreeMap<String, Vec<String>>, | ||||||
| @@ -69,7 +69,7 @@ pub fn push_synonyms_addition( | |||||||
| } | } | ||||||
|  |  | ||||||
| pub fn apply_synonyms_addition( | pub fn apply_synonyms_addition( | ||||||
|     writer: &mut zlmdb::RwTxn, |     writer: &mut heed::RwTxn, | ||||||
|     main_store: store::Main, |     main_store: store::Main, | ||||||
|     synonyms_store: store::Synonyms, |     synonyms_store: store::Synonyms, | ||||||
|     addition: BTreeMap<String, Vec<String>>, |     addition: BTreeMap<String, Vec<String>>, | ||||||
|   | |||||||
| @@ -49,7 +49,7 @@ impl SynonymsDeletion { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn finalize(self, writer: &mut zlmdb::RwTxn) -> MResult<u64> { |     pub fn finalize(self, writer: &mut heed::RwTxn) -> MResult<u64> { | ||||||
|         let _ = self.updates_notifier.send(()); |         let _ = self.updates_notifier.send(()); | ||||||
|         let update_id = push_synonyms_deletion( |         let update_id = push_synonyms_deletion( | ||||||
|             writer, |             writer, | ||||||
| @@ -62,7 +62,7 @@ impl SynonymsDeletion { | |||||||
| } | } | ||||||
|  |  | ||||||
| pub fn push_synonyms_deletion( | pub fn push_synonyms_deletion( | ||||||
|     writer: &mut zlmdb::RwTxn, |     writer: &mut heed::RwTxn, | ||||||
|     updates_store: store::Updates, |     updates_store: store::Updates, | ||||||
|     updates_results_store: store::UpdatesResults, |     updates_results_store: store::UpdatesResults, | ||||||
|     deletion: BTreeMap<String, Option<Vec<String>>>, |     deletion: BTreeMap<String, Option<Vec<String>>>, | ||||||
| @@ -76,7 +76,7 @@ pub fn push_synonyms_deletion( | |||||||
| } | } | ||||||
|  |  | ||||||
| pub fn apply_synonyms_deletion( | pub fn apply_synonyms_deletion( | ||||||
|     writer: &mut zlmdb::RwTxn, |     writer: &mut heed::RwTxn, | ||||||
|     main_store: store::Main, |     main_store: store::Main, | ||||||
|     synonyms_store: store::Synonyms, |     synonyms_store: store::Synonyms, | ||||||
|     deletion: BTreeMap<String, Option<Vec<String>>>, |     deletion: BTreeMap<String, Option<Vec<String>>>, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user