mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 05:26:27 +00:00 
			
		
		
		
	fixes
This commit is contained in:
		| @@ -1395,15 +1395,17 @@ impl IndexScheduler { | ||||
|                 Ok(tasks) | ||||
|             } | ||||
|             IndexOperation::DocumentEdition { mut task, .. } => { | ||||
|                 let (filter, context, code) = | ||||
|                     if let KindWithContent::DocumentEdition { | ||||
|                         filter_expr, context, function, .. | ||||
|                     } = &task.kind | ||||
|                     { | ||||
|                         (filter_expr, context, function) | ||||
|                     } else { | ||||
|                         unreachable!() | ||||
|                     }; | ||||
|                 let (filter, code) = if let KindWithContent::DocumentEdition { | ||||
|                     filter_expr, | ||||
|                     context: _, | ||||
|                     function, | ||||
|                     .. | ||||
|                 } = &task.kind | ||||
|                 { | ||||
|                     (filter_expr, function) | ||||
|                 } else { | ||||
|                     unreachable!() | ||||
|                 }; | ||||
|  | ||||
|                 let candidates = match filter.as_ref().map(Filter::from_json) { | ||||
|                     Some(Ok(Some(filter))) => { | ||||
|   | ||||
| @@ -971,6 +971,8 @@ impl IndexScheduler { | ||||
|         let ProcessingTasks { started_at, processing, progress, .. } = | ||||
|             self.processing_tasks.read().map_err(|_| Error::CorruptedTaskQueue)?.clone(); | ||||
|  | ||||
|         let _ = progress; | ||||
|  | ||||
|         let ret = tasks.into_iter(); | ||||
|         if processing.is_empty() { | ||||
|             Ok((ret.collect(), total)) | ||||
|   | ||||
| @@ -220,11 +220,12 @@ pub fn read_json(input: &File, output: impl io::Write) -> Result<u64> { | ||||
|  | ||||
|     let mut out = BufWriter::new(output); | ||||
|     let mut deserializer = serde_json::Deserializer::from_slice(&input); | ||||
|     let count = match array_each(&mut deserializer, |obj: &RawValue| { | ||||
|     let res = array_each(&mut deserializer, |obj: &RawValue| { | ||||
|         doc_alloc.reset(); | ||||
|         let map = RawMap::from_raw_value(obj, &doc_alloc)?; | ||||
|         to_writer(&mut out, &map) | ||||
|     }) { | ||||
|     }); | ||||
|     let count = match res { | ||||
|         // The json data has been deserialized and does not need to be processed again. | ||||
|         // The data has been transferred to the writer during the deserialization process. | ||||
|         Ok(Ok(count)) => count, | ||||
|   | ||||
| @@ -156,6 +156,7 @@ impl FacetedDocidsExtractor { | ||||
|         res | ||||
|     } | ||||
|  | ||||
|     #[allow(clippy::too_many_arguments)] | ||||
|     fn facet_fn_with_options<'extractor, 'doc>( | ||||
|         doc_alloc: &'doc Bump, | ||||
|         cached_sorter: &mut BalancedCaches<'extractor>, | ||||
| @@ -336,6 +337,7 @@ fn truncate_str(s: &str) -> &str { | ||||
| } | ||||
|  | ||||
| impl FacetedDocidsExtractor { | ||||
|     #[allow(clippy::too_many_arguments)] | ||||
|     #[tracing::instrument(level = "trace", skip_all, target = "indexing::extract::faceted")] | ||||
|     pub fn run_extraction< | ||||
|         'pl, | ||||
|   | ||||
| @@ -106,6 +106,7 @@ impl<'pl> DocumentOperation<'pl> { | ||||
|     } | ||||
| } | ||||
|  | ||||
| #[allow(clippy::too_many_arguments)] | ||||
| fn extract_addition_payload_changes<'r, 'pl: 'r>( | ||||
|     indexer: &'pl Bump, | ||||
|     index: &Index, | ||||
|   | ||||
| @@ -1,37 +1,16 @@ | ||||
| use std::cell::{Ref, RefCell, RefMut}; | ||||
| use std::cell::{RefCell, RefMut}; | ||||
|  | ||||
| pub trait RefCellExt<T: ?Sized> { | ||||
|     fn try_borrow_or_yield(&self) -> std::result::Result<Ref<'_, T>, std::cell::BorrowError>; | ||||
|     fn try_borrow_mut_or_yield( | ||||
|         &self, | ||||
|     ) -> std::result::Result<RefMut<'_, T>, std::cell::BorrowMutError>; | ||||
|  | ||||
|     fn borrow_or_yield(&self) -> Ref<'_, T> { | ||||
|         self.try_borrow_or_yield().unwrap() | ||||
|     } | ||||
|  | ||||
|     fn borrow_mut_or_yield(&self) -> RefMut<'_, T> { | ||||
|         self.try_borrow_mut_or_yield().unwrap() | ||||
|     } | ||||
| } | ||||
|  | ||||
| impl<T: ?Sized> RefCellExt<T> for RefCell<T> { | ||||
|     fn try_borrow_or_yield(&self) -> std::result::Result<Ref<'_, T>, std::cell::BorrowError> { | ||||
|         /// TODO: move this trait and impl elsewhere | ||||
|         loop { | ||||
|             match self.try_borrow() { | ||||
|                 Ok(borrow) => break Ok(borrow), | ||||
|                 Err(error) => { | ||||
|                     tracing::warn!("dynamic borrow failed, yielding to local tasks"); | ||||
|                     match rayon::yield_local() { | ||||
|                         Some(rayon::Yield::Executed) => continue, | ||||
|                         _ => return Err(error), | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     fn try_borrow_mut_or_yield( | ||||
|         &self, | ||||
|     ) -> std::result::Result<RefMut<'_, T>, std::cell::BorrowMutError> { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user