mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 21:16:28 +00:00 
			
		
		
		
	Replace the panic in the merge function by actual errors
This commit is contained in:
		| @@ -1,3 +1,4 @@ | ||||
| use anyhow::bail; | ||||
| use bstr::ByteSlice as _; | ||||
| use fst::IntoStreamer; | ||||
| use roaring::RoaringBitmap; | ||||
| @@ -8,7 +9,7 @@ const WORDS_FST_KEY: &[u8] = crate::WORDS_FST_KEY.as_bytes(); | ||||
| const HEADERS_KEY: &[u8] = crate::HEADERS_KEY.as_bytes(); | ||||
| const DOCUMENTS_IDS_KEY: &[u8] = crate::DOCUMENTS_IDS_KEY.as_bytes(); | ||||
|  | ||||
| pub fn main_merge(key: &[u8], values: &[Vec<u8>]) -> Result<Vec<u8>, ()> { | ||||
| pub fn main_merge(key: &[u8], values: &[Vec<u8>]) -> anyhow::Result<Vec<u8>> { | ||||
|     match key { | ||||
|         WORDS_FST_KEY => { | ||||
|             let fsts: Vec<_> = values.iter().map(|v| fst::Set::new(v).unwrap()).collect(); | ||||
| @@ -27,42 +28,42 @@ pub fn main_merge(key: &[u8], values: &[Vec<u8>]) -> Result<Vec<u8>, ()> { | ||||
|             Ok(values[0].to_vec()) | ||||
|         }, | ||||
|         DOCUMENTS_IDS_KEY => word_docids_merge(&[], values), | ||||
|         otherwise => panic!("wut {:?}", otherwise), | ||||
|         otherwise => bail!("wut {:?}", otherwise), | ||||
|     } | ||||
| } | ||||
|  | ||||
| pub fn word_docids_merge(_key: &[u8], values: &[Vec<u8>]) -> Result<Vec<u8>, ()> { | ||||
| pub fn word_docids_merge(_key: &[u8], values: &[Vec<u8>]) -> anyhow::Result<Vec<u8>> { | ||||
|     let (head, tail) = values.split_first().unwrap(); | ||||
|     let mut head = RoaringBitmap::deserialize_from(head.as_slice()).unwrap(); | ||||
|     let mut head = RoaringBitmap::deserialize_from(head.as_slice())?; | ||||
|  | ||||
|     for value in tail { | ||||
|         let bitmap = RoaringBitmap::deserialize_from(value.as_slice()).unwrap(); | ||||
|         let bitmap = RoaringBitmap::deserialize_from(value.as_slice())?; | ||||
|         head.union_with(&bitmap); | ||||
|     } | ||||
|  | ||||
|     let mut vec = Vec::with_capacity(head.serialized_size()); | ||||
|     head.serialize_into(&mut vec).unwrap(); | ||||
|     head.serialize_into(&mut vec)?; | ||||
|     Ok(vec) | ||||
| } | ||||
|  | ||||
| pub fn docid_word_positions_merge(key: &[u8], _values: &[Vec<u8>]) -> Result<Vec<u8>, ()> { | ||||
|     panic!("merging docid word positions is an error ({:?})", key.as_bstr()) | ||||
| pub fn docid_word_positions_merge(key: &[u8], _values: &[Vec<u8>]) -> anyhow::Result<Vec<u8>> { | ||||
|     bail!("merging docid word positions is an error ({:?})", key.as_bstr()) | ||||
| } | ||||
|  | ||||
| pub fn words_pairs_proximities_docids_merge(_key: &[u8], values: &[Vec<u8>]) -> Result<Vec<u8>, ()> { | ||||
| pub fn words_pairs_proximities_docids_merge(_key: &[u8], values: &[Vec<u8>]) -> anyhow::Result<Vec<u8>> { | ||||
|     let (head, tail) = values.split_first().unwrap(); | ||||
|     let mut head = CboRoaringBitmapCodec::deserialize_from(head.as_slice()).unwrap(); | ||||
|     let mut head = CboRoaringBitmapCodec::deserialize_from(head.as_slice())?; | ||||
|  | ||||
|     for value in tail { | ||||
|         let bitmap = CboRoaringBitmapCodec::deserialize_from(value.as_slice()).unwrap(); | ||||
|         let bitmap = CboRoaringBitmapCodec::deserialize_from(value.as_slice())?; | ||||
|         head.union_with(&bitmap); | ||||
|     } | ||||
|  | ||||
|     let mut vec = Vec::new(); | ||||
|     CboRoaringBitmapCodec::serialize_into(&head, &mut vec).unwrap(); | ||||
|     CboRoaringBitmapCodec::serialize_into(&head, &mut vec)?; | ||||
|     Ok(vec) | ||||
| } | ||||
|  | ||||
| pub fn documents_merge(key: &[u8], _values: &[Vec<u8>]) -> Result<Vec<u8>, ()> { | ||||
|     panic!("merging documents is an error ({:?})", key.as_bstr()) | ||||
| pub fn documents_merge(key: &[u8], _values: &[Vec<u8>]) -> anyhow::Result<Vec<u8>> { | ||||
|     bail!("merging documents is an error ({:?})", key.as_bstr()) | ||||
| } | ||||
|   | ||||
| @@ -81,7 +81,7 @@ enum WriteMethod { | ||||
|     GetMergePut, | ||||
| } | ||||
|  | ||||
| type MergeFn = fn(&[u8], &[Vec<u8>]) -> Result<Vec<u8>, ()>; | ||||
| type MergeFn = fn(&[u8], &[Vec<u8>]) -> anyhow::Result<Vec<u8>>; | ||||
|  | ||||
| fn create_writer(typ: CompressionType, level: Option<u32>, file: File) -> io::Result<Writer<File>> { | ||||
|     let mut builder = Writer::builder(); | ||||
| @@ -159,7 +159,7 @@ fn merge_into_lmdb_database( | ||||
|             while let Some((k, v)) = in_iter.next()? { | ||||
|                 match database.get::<_, ByteSlice, ByteSlice>(wtxn, k)? { | ||||
|                     Some(old_val) => { | ||||
|                         // TODO improve the function signature and avoid alocating here! | ||||
|                         // TODO improve the function signature and avoid allocating here! | ||||
|                         let vals = vec![old_val.to_vec(), v.to_vec()]; | ||||
|                         let val = merge(k, &vals).expect("merge failed"); | ||||
|                         database.put::<_, ByteSlice, ByteSlice>(wtxn, k, &val)? | ||||
| @@ -386,12 +386,9 @@ fn run_intern<'a>( | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     debug!("Retrieving the number of documents..."); | ||||
|     let count = index.number_of_documents(&wtxn)?; | ||||
|  | ||||
|     wtxn.commit()?; | ||||
|  | ||||
|     info!("Wrote {} documents in {:.02?}", count, before_indexing.elapsed()); | ||||
|     info!("Update processed in {:.02?}", before_indexing.elapsed()); | ||||
|  | ||||
|     Ok(()) | ||||
| } | ||||
|   | ||||
| @@ -377,7 +377,7 @@ pub fn run(opt: Opt) -> anyhow::Result<()> { | ||||
|  | ||||
|         let meta = String::from("I am the metadata"); | ||||
|         let update_id = update_store.register_update(&meta, &mmap[..]).unwrap(); | ||||
|         update_status_sender.send(UpdateStatus::Pending { update_id, meta }).unwrap(); | ||||
|         let _ = update_status_sender.send(UpdateStatus::Pending { update_id, meta }); | ||||
|         eprintln!("update {} registered", update_id); | ||||
|  | ||||
|         Ok(warp::reply()) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user