mirror of
https://github.com/meilisearch/meilisearch.git
synced 2024-11-22 18:17:39 +08:00
Add SP to into_changes
This commit is contained in:
parent
567bd4538b
commit
867138f166
@ -9,10 +9,11 @@ use serde_json::value::RawValue;
|
|||||||
use serde_json::Deserializer;
|
use serde_json::Deserializer;
|
||||||
|
|
||||||
use super::super::document_change::DocumentChange;
|
use super::super::document_change::DocumentChange;
|
||||||
use super::document_changes::{DocumentChangeContext, DocumentChanges};
|
use super::document_changes::{DocumentChangeContext, DocumentChanges, Progress};
|
||||||
use super::retrieve_or_guess_primary_key;
|
use super::retrieve_or_guess_primary_key;
|
||||||
use crate::documents::PrimaryKey;
|
use crate::documents::PrimaryKey;
|
||||||
use crate::update::new::document::Versions;
|
use crate::update::new::document::Versions;
|
||||||
|
use crate::update::new::steps::Step;
|
||||||
use crate::update::new::thread_local::MostlySend;
|
use crate::update::new::thread_local::MostlySend;
|
||||||
use crate::update::new::{Deletion, Insertion, Update};
|
use crate::update::new::{Deletion, Insertion, Update};
|
||||||
use crate::update::{AvailableIds, IndexDocumentsMethod};
|
use crate::update::{AvailableIds, IndexDocumentsMethod};
|
||||||
@ -41,7 +42,8 @@ impl<'pl> DocumentOperation<'pl> {
|
|||||||
self.operations.push(Payload::Deletion(to_delete))
|
self.operations.push(Payload::Deletion(to_delete))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn into_changes<MSP>(
|
#[allow(clippy::too_many_arguments)]
|
||||||
|
pub fn into_changes<MSP, SP>(
|
||||||
self,
|
self,
|
||||||
indexer: &'pl Bump,
|
indexer: &'pl Bump,
|
||||||
index: &Index,
|
index: &Index,
|
||||||
@ -49,9 +51,11 @@ impl<'pl> DocumentOperation<'pl> {
|
|||||||
primary_key_from_op: Option<&'pl str>,
|
primary_key_from_op: Option<&'pl str>,
|
||||||
new_fields_ids_map: &mut FieldsIdsMap,
|
new_fields_ids_map: &mut FieldsIdsMap,
|
||||||
must_stop_processing: &MSP,
|
must_stop_processing: &MSP,
|
||||||
|
send_progress: &SP,
|
||||||
) -> Result<(DocumentOperationChanges<'pl>, Vec<PayloadStats>, Option<PrimaryKey<'pl>>)>
|
) -> Result<(DocumentOperationChanges<'pl>, Vec<PayloadStats>, Option<PrimaryKey<'pl>>)>
|
||||||
where
|
where
|
||||||
MSP: Fn() -> bool,
|
MSP: Fn() -> bool,
|
||||||
|
SP: Fn(Progress),
|
||||||
{
|
{
|
||||||
let Self { operations, method } = self;
|
let Self { operations, method } = self;
|
||||||
|
|
||||||
@ -61,10 +65,18 @@ impl<'pl> DocumentOperation<'pl> {
|
|||||||
let mut docids_version_offsets = hashbrown::HashMap::new();
|
let mut docids_version_offsets = hashbrown::HashMap::new();
|
||||||
let mut primary_key = None;
|
let mut primary_key = None;
|
||||||
|
|
||||||
for operation in operations {
|
let payload_count = operations.len();
|
||||||
if (must_stop_processing)() {
|
|
||||||
|
for (payload_index, operation) in operations.into_iter().enumerate() {
|
||||||
|
if must_stop_processing() {
|
||||||
return Err(InternalError::AbortedIndexation.into());
|
return Err(InternalError::AbortedIndexation.into());
|
||||||
}
|
}
|
||||||
|
send_progress(Progress::from_step_documents(
|
||||||
|
Step::PreparingPayloads,
|
||||||
|
payload_index as u32,
|
||||||
|
payload_count as u32,
|
||||||
|
));
|
||||||
|
|
||||||
let mut bytes = 0;
|
let mut bytes = 0;
|
||||||
let result = match operation {
|
let result = match operation {
|
||||||
Payload::Addition(payload) => extract_addition_payload_changes(
|
Payload::Addition(payload) => extract_addition_payload_changes(
|
||||||
@ -102,10 +114,15 @@ impl<'pl> DocumentOperation<'pl> {
|
|||||||
Err(Error::UserError(user_error)) => Some(user_error),
|
Err(Error::UserError(user_error)) => Some(user_error),
|
||||||
Err(e) => return Err(e),
|
Err(e) => return Err(e),
|
||||||
};
|
};
|
||||||
|
|
||||||
operations_stats.push(PayloadStats { document_count, bytes, error });
|
operations_stats.push(PayloadStats { document_count, bytes, error });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
send_progress(Progress::from_step_documents(
|
||||||
|
Step::PreparingPayloads,
|
||||||
|
payload_count as u32,
|
||||||
|
payload_count as u32,
|
||||||
|
));
|
||||||
|
|
||||||
// TODO We must drain the HashMap into a Vec because rayon::hash_map::IntoIter: !Clone
|
// TODO We must drain the HashMap into a Vec because rayon::hash_map::IntoIter: !Clone
|
||||||
let mut docids_version_offsets: bumpalo::collections::vec::Vec<_> =
|
let mut docids_version_offsets: bumpalo::collections::vec::Vec<_> =
|
||||||
docids_version_offsets.drain().collect_in(indexer);
|
docids_version_offsets.drain().collect_in(indexer);
|
||||||
|
@ -3,6 +3,7 @@ use enum_iterator::Sequence;
|
|||||||
#[derive(Debug, Clone, Copy, PartialEq, Eq, Sequence)]
|
#[derive(Debug, Clone, Copy, PartialEq, Eq, Sequence)]
|
||||||
#[repr(u16)]
|
#[repr(u16)]
|
||||||
pub enum Step {
|
pub enum Step {
|
||||||
|
PreparingPayloads,
|
||||||
ExtractingDocuments,
|
ExtractingDocuments,
|
||||||
ExtractingFacets,
|
ExtractingFacets,
|
||||||
ExtractingWords,
|
ExtractingWords,
|
||||||
@ -20,6 +21,7 @@ pub enum Step {
|
|||||||
impl Step {
|
impl Step {
|
||||||
pub fn name(&self) -> &'static str {
|
pub fn name(&self) -> &'static str {
|
||||||
match self {
|
match self {
|
||||||
|
Step::PreparingPayloads => "preparing update file",
|
||||||
Step::ExtractingDocuments => "extracting documents",
|
Step::ExtractingDocuments => "extracting documents",
|
||||||
Step::ExtractingFacets => "extracting facets",
|
Step::ExtractingFacets => "extracting facets",
|
||||||
Step::ExtractingWords => "extracting words",
|
Step::ExtractingWords => "extracting words",
|
||||||
|
Loading…
Reference in New Issue
Block a user