mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 21:16:28 +00:00 
			
		
		
		
	Make the changes to use heed v0.20-alpha.6
This commit is contained in:
		| @@ -7,8 +7,8 @@ use clap::{Parser, Subcommand}; | ||||
| use dump::{DumpWriter, IndexMetadata}; | ||||
| use file_store::FileStore; | ||||
| use meilisearch_auth::AuthController; | ||||
| use meilisearch_types::heed::types::{OwnedType, SerdeJson, Str}; | ||||
| use meilisearch_types::heed::{Database, Env, EnvOpenOptions, PolyDatabase, RoTxn, RwTxn}; | ||||
| use meilisearch_types::heed::types::{SerdeJson, Str}; | ||||
| use meilisearch_types::heed::{Database, Env, EnvOpenOptions, RoTxn, RwTxn, Unspecified}; | ||||
| use meilisearch_types::milli::documents::{obkv_to_object, DocumentsBatchReader}; | ||||
| use meilisearch_types::milli::{obkv_to_json, BEU32}; | ||||
| use meilisearch_types::tasks::{Status, Task}; | ||||
| @@ -148,15 +148,17 @@ fn try_opening_poly_database( | ||||
|     env: &Env, | ||||
|     rtxn: &RoTxn, | ||||
|     db_name: &str, | ||||
| ) -> anyhow::Result<PolyDatabase> { | ||||
|     env.open_poly_database(rtxn, Some(db_name)) | ||||
| ) -> anyhow::Result<Database<Unspecified, Unspecified>> { | ||||
|     env.database_options() | ||||
|         .name(db_name) | ||||
|         .open(rtxn) | ||||
|         .with_context(|| format!("While opening the {db_name:?} poly database"))? | ||||
|         .with_context(|| format!("Missing the {db_name:?} poly database")) | ||||
| } | ||||
|  | ||||
| fn try_clearing_poly_database( | ||||
|     wtxn: &mut RwTxn, | ||||
|     database: PolyDatabase, | ||||
|     database: Database<Unspecified, Unspecified>, | ||||
|     db_name: &str, | ||||
| ) -> anyhow::Result<()> { | ||||
|     database.clear(wtxn).with_context(|| format!("While clearing the {db_name:?} database")) | ||||
| @@ -212,7 +214,7 @@ fn export_a_dump( | ||||
|     eprintln!("Successfully dumped {count} keys!"); | ||||
|  | ||||
|     let rtxn = env.read_txn()?; | ||||
|     let all_tasks: Database<OwnedType<BEU32>, SerdeJson<Task>> = | ||||
|     let all_tasks: Database<BEU32, SerdeJson<Task>> = | ||||
|         try_opening_database(&env, &rtxn, "all-tasks")?; | ||||
|     let index_mapping: Database<Str, UuidCodec> = | ||||
|         try_opening_database(&env, &rtxn, "index-mapping")?; | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| use std::borrow::Cow; | ||||
| use std::convert::TryInto; | ||||
|  | ||||
| use meilisearch_types::heed::{BytesDecode, BytesEncode}; | ||||
| use meilisearch_types::heed::{BoxedError, BytesDecode, BytesEncode}; | ||||
| use uuid::Uuid; | ||||
|  | ||||
| /// A heed codec for value of struct Uuid. | ||||
| @@ -10,15 +10,15 @@ pub struct UuidCodec; | ||||
| impl<'a> BytesDecode<'a> for UuidCodec { | ||||
|     type DItem = Uuid; | ||||
|  | ||||
|     fn bytes_decode(bytes: &'a [u8]) -> Option<Self::DItem> { | ||||
|         bytes.try_into().ok().map(Uuid::from_bytes) | ||||
|     fn bytes_decode(bytes: &'a [u8]) -> Result<Self::DItem, BoxedError> { | ||||
|         bytes.try_into().map(Uuid::from_bytes).map_err(Into::into) | ||||
|     } | ||||
| } | ||||
|  | ||||
| impl BytesEncode<'_> for UuidCodec { | ||||
|     type EItem = Uuid; | ||||
|  | ||||
|     fn bytes_encode(item: &Self::EItem) -> Option<Cow<[u8]>> { | ||||
|         Some(Cow::Borrowed(item.as_bytes())) | ||||
|     fn bytes_encode(item: &Self::EItem) -> Result<Cow<[u8]>, BoxedError> { | ||||
|         Ok(Cow::Borrowed(item.as_bytes())) | ||||
|     } | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user