mirror of
https://github.com/meilisearch/meilisearch.git
synced 2025-01-25 04:23:12 +08:00
42 lines
1.2 KiB
Rust
42 lines
1.2 KiB
Rust
use std::sync::Arc;
|
|
|
|
use rayon::iter::{ParallelBridge, ParallelIterator};
|
|
use roaring::RoaringBitmap;
|
|
|
|
use super::DocumentChanges;
|
|
use crate::update::new::{Deletion, DocumentChange, ItemsPool};
|
|
use crate::{FieldsIdsMap, Index, Result};
|
|
|
|
pub struct DocumentDeletion {
|
|
pub to_delete: RoaringBitmap,
|
|
}
|
|
|
|
impl DocumentDeletion {
|
|
pub fn new() -> Self {
|
|
Self { to_delete: Default::default() }
|
|
}
|
|
|
|
pub fn delete_documents_by_docids(&mut self, docids: RoaringBitmap) {
|
|
self.to_delete |= docids;
|
|
}
|
|
}
|
|
|
|
impl<'p> DocumentChanges<'p> for DocumentDeletion {
|
|
type Parameter = &'p Index;
|
|
|
|
fn document_changes(
|
|
self,
|
|
_fields_ids_map: &mut FieldsIdsMap,
|
|
param: Self::Parameter,
|
|
) -> Result<impl ParallelIterator<Item = Result<DocumentChange>> + Clone + 'p> {
|
|
let index = param;
|
|
let items = Arc::new(ItemsPool::new(|| index.read_txn().map_err(crate::Error::from)));
|
|
Ok(self.to_delete.into_iter().par_bridge().map_with(items, |items, docid| {
|
|
items.with(|rtxn| {
|
|
let current = index.document(rtxn, docid)?;
|
|
Ok(DocumentChange::Deletion(Deletion::create(docid, current.boxed())))
|
|
})
|
|
}))
|
|
}
|
|
}
|