mirror of
https://github.com/meilisearch/MeiliSearch
synced 2025-02-09 03:53:27 +01:00
Remove, now useless, the WriteMethod enum
This commit is contained in:
parent
e9c02173cf
commit
51d1e64b23
@ -15,9 +15,7 @@ use crate::heed_codec::facet::{
|
|||||||
FacetStringLevelZeroValueCodec, FacetStringZeroBoundsValueCodec,
|
FacetStringLevelZeroValueCodec, FacetStringZeroBoundsValueCodec,
|
||||||
};
|
};
|
||||||
use crate::heed_codec::CboRoaringBitmapCodec;
|
use crate::heed_codec::CboRoaringBitmapCodec;
|
||||||
use crate::update::index_documents::{
|
use crate::update::index_documents::{create_writer, write_into_lmdb_database, writer_into_reader};
|
||||||
create_writer, write_into_lmdb_database, writer_into_reader, WriteMethod,
|
|
||||||
};
|
|
||||||
use crate::{FieldId, Index, Result};
|
use crate::{FieldId, Index, Result};
|
||||||
|
|
||||||
pub struct Facets<'t, 'u, 'i> {
|
pub struct Facets<'t, 'u, 'i> {
|
||||||
@ -120,7 +118,6 @@ impl<'t, 'u, 'i> Facets<'t, 'u, 'i> {
|
|||||||
*self.index.facet_id_f64_docids.as_polymorph(),
|
*self.index.facet_id_f64_docids.as_polymorph(),
|
||||||
facet_number_levels,
|
facet_number_levels,
|
||||||
|_, _| Err(InternalError::IndexingMergingKeys { process: "facet number levels" })?,
|
|_, _| Err(InternalError::IndexingMergingKeys { process: "facet number levels" })?,
|
||||||
WriteMethod::GetMergePut,
|
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
write_into_lmdb_database(
|
write_into_lmdb_database(
|
||||||
@ -128,7 +125,6 @@ impl<'t, 'u, 'i> Facets<'t, 'u, 'i> {
|
|||||||
*self.index.facet_id_string_docids.as_polymorph(),
|
*self.index.facet_id_string_docids.as_polymorph(),
|
||||||
facet_string_levels,
|
facet_string_levels,
|
||||||
|_, _| Err(InternalError::IndexingMergingKeys { process: "facet string levels" })?,
|
|_, _| Err(InternalError::IndexingMergingKeys { process: "facet string levels" })?,
|
||||||
WriteMethod::GetMergePut,
|
|
||||||
)?;
|
)?;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9,7 +9,6 @@ use log::debug;
|
|||||||
|
|
||||||
use super::{ClonableMmap, MergeFn};
|
use super::{ClonableMmap, MergeFn};
|
||||||
use crate::error::InternalError;
|
use crate::error::InternalError;
|
||||||
use crate::update::index_documents::WriteMethod;
|
|
||||||
use crate::Result;
|
use crate::Result;
|
||||||
|
|
||||||
pub type CursorClonableMmap = io::Cursor<ClonableMmap>;
|
pub type CursorClonableMmap = io::Cursor<ClonableMmap>;
|
||||||
@ -169,34 +168,22 @@ pub fn write_into_lmdb_database(
|
|||||||
database: heed::PolyDatabase,
|
database: heed::PolyDatabase,
|
||||||
mut reader: Reader<File>,
|
mut reader: Reader<File>,
|
||||||
merge: MergeFn,
|
merge: MergeFn,
|
||||||
method: WriteMethod,
|
|
||||||
) -> Result<()> {
|
) -> Result<()> {
|
||||||
debug!("Writing MTBL stores...");
|
debug!("Writing MTBL stores...");
|
||||||
let before = Instant::now();
|
let before = Instant::now();
|
||||||
|
|
||||||
match method {
|
while let Some((k, v)) = reader.next()? {
|
||||||
WriteMethod::Append => {
|
let mut iter = database.prefix_iter_mut::<_, ByteSlice, ByteSlice>(wtxn, k)?;
|
||||||
let mut out_iter = database.iter_mut::<_, ByteSlice, ByteSlice>(wtxn)?;
|
match iter.next().transpose()? {
|
||||||
while let Some((k, v)) = reader.next()? {
|
Some((key, old_val)) if key == k => {
|
||||||
|
let vals = &[Cow::Borrowed(old_val), Cow::Borrowed(v)][..];
|
||||||
|
let val = merge(k, &vals)?;
|
||||||
// safety: we don't keep references from inside the LMDB database.
|
// safety: we don't keep references from inside the LMDB database.
|
||||||
unsafe { out_iter.append(k, v)? };
|
unsafe { iter.put_current(k, &val)? };
|
||||||
}
|
}
|
||||||
}
|
_ => {
|
||||||
WriteMethod::GetMergePut => {
|
drop(iter);
|
||||||
while let Some((k, v)) = reader.next()? {
|
database.put::<_, ByteSlice, ByteSlice>(wtxn, k, v)?;
|
||||||
let mut iter = database.prefix_iter_mut::<_, ByteSlice, ByteSlice>(wtxn, k)?;
|
|
||||||
match iter.next().transpose()? {
|
|
||||||
Some((key, old_val)) if key == k => {
|
|
||||||
let vals = &[Cow::Borrowed(old_val), Cow::Borrowed(v)][..];
|
|
||||||
let val = merge(k, &vals)?;
|
|
||||||
// safety: we don't keep references from inside the LMDB database.
|
|
||||||
unsafe { iter.put_current(k, &val)? };
|
|
||||||
}
|
|
||||||
_ => {
|
|
||||||
drop(iter);
|
|
||||||
database.put::<_, ByteSlice, ByteSlice>(wtxn, k, v)?;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -210,12 +197,11 @@ pub fn sorter_into_lmdb_database(
|
|||||||
database: heed::PolyDatabase,
|
database: heed::PolyDatabase,
|
||||||
sorter: Sorter<MergeFn>,
|
sorter: Sorter<MergeFn>,
|
||||||
merge: MergeFn,
|
merge: MergeFn,
|
||||||
method: WriteMethod,
|
|
||||||
) -> Result<()> {
|
) -> Result<()> {
|
||||||
debug!("Writing MTBL sorter...");
|
debug!("Writing MTBL sorter...");
|
||||||
let before = Instant::now();
|
let before = Instant::now();
|
||||||
|
|
||||||
merger_iter_into_lmdb_database(wtxn, database, sorter.into_merger_iter()?, merge, method)?;
|
merger_iter_into_lmdb_database(wtxn, database, sorter.into_merger_iter()?, merge)?;
|
||||||
|
|
||||||
debug!("MTBL sorter writen in {:.02?}!", before.elapsed());
|
debug!("MTBL sorter writen in {:.02?}!", before.elapsed());
|
||||||
Ok(())
|
Ok(())
|
||||||
@ -226,34 +212,22 @@ fn merger_iter_into_lmdb_database<R: io::Read>(
|
|||||||
database: heed::PolyDatabase,
|
database: heed::PolyDatabase,
|
||||||
mut sorter: MergerIter<R, MergeFn>,
|
mut sorter: MergerIter<R, MergeFn>,
|
||||||
merge: MergeFn,
|
merge: MergeFn,
|
||||||
method: WriteMethod,
|
|
||||||
) -> Result<()> {
|
) -> Result<()> {
|
||||||
match method {
|
while let Some((k, v)) = sorter.next()? {
|
||||||
WriteMethod::Append => {
|
let mut iter = database.prefix_iter_mut::<_, ByteSlice, ByteSlice>(wtxn, k)?;
|
||||||
let mut out_iter = database.iter_mut::<_, ByteSlice, ByteSlice>(wtxn)?;
|
match iter.next().transpose()? {
|
||||||
while let Some((k, v)) = sorter.next()? {
|
Some((key, old_val)) if key == k => {
|
||||||
|
let vals = vec![Cow::Borrowed(old_val), Cow::Borrowed(v)];
|
||||||
|
let val = merge(k, &vals).map_err(|_| {
|
||||||
|
// TODO just wrap this error?
|
||||||
|
InternalError::IndexingMergingKeys { process: "get-put-merge" }
|
||||||
|
})?;
|
||||||
// safety: we don't keep references from inside the LMDB database.
|
// safety: we don't keep references from inside the LMDB database.
|
||||||
unsafe { out_iter.append(k, v)? };
|
unsafe { iter.put_current(k, &val)? };
|
||||||
}
|
}
|
||||||
}
|
_ => {
|
||||||
WriteMethod::GetMergePut => {
|
drop(iter);
|
||||||
while let Some((k, v)) = sorter.next()? {
|
database.put::<_, ByteSlice, ByteSlice>(wtxn, k, v)?;
|
||||||
let mut iter = database.prefix_iter_mut::<_, ByteSlice, ByteSlice>(wtxn, k)?;
|
|
||||||
match iter.next().transpose()? {
|
|
||||||
Some((key, old_val)) if key == k => {
|
|
||||||
let vals = vec![Cow::Borrowed(old_val), Cow::Borrowed(v)];
|
|
||||||
let val = merge(k, &vals).map_err(|_| {
|
|
||||||
// TODO just wrap this error?
|
|
||||||
InternalError::IndexingMergingKeys { process: "get-put-merge" }
|
|
||||||
})?;
|
|
||||||
// safety: we don't keep references from inside the LMDB database.
|
|
||||||
unsafe { iter.put_current(k, &val)? };
|
|
||||||
}
|
|
||||||
_ => {
|
|
||||||
drop(iter);
|
|
||||||
database.put::<_, ByteSlice, ByteSlice>(wtxn, k, v)?;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -59,12 +59,6 @@ impl Default for IndexDocumentsMethod {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Copy, Clone)]
|
|
||||||
pub enum WriteMethod {
|
|
||||||
Append,
|
|
||||||
GetMergePut,
|
|
||||||
}
|
|
||||||
|
|
||||||
pub struct IndexDocuments<'t, 'u, 'i, 'a, F> {
|
pub struct IndexDocuments<'t, 'u, 'i, 'a, F> {
|
||||||
wtxn: &'t mut heed::RwTxn<'i, 'u>,
|
wtxn: &'t mut heed::RwTxn<'i, 'u>,
|
||||||
index: &'i Index,
|
index: &'i Index,
|
||||||
|
@ -7,7 +7,7 @@ use slice_group_by::GroupBy;
|
|||||||
|
|
||||||
use crate::update::index_documents::{
|
use crate::update::index_documents::{
|
||||||
create_sorter, fst_stream_into_hashset, fst_stream_into_vec, merge_roaring_bitmaps,
|
create_sorter, fst_stream_into_hashset, fst_stream_into_vec, merge_roaring_bitmaps,
|
||||||
sorter_into_lmdb_database, CursorClonableMmap, MergeFn, WriteMethod,
|
sorter_into_lmdb_database, CursorClonableMmap, MergeFn,
|
||||||
};
|
};
|
||||||
use crate::{Index, Result};
|
use crate::{Index, Result};
|
||||||
|
|
||||||
@ -126,7 +126,6 @@ impl<'t, 'u, 'i> WordPrefixDocids<'t, 'u, 'i> {
|
|||||||
*self.index.word_prefix_docids.as_polymorph(),
|
*self.index.word_prefix_docids.as_polymorph(),
|
||||||
prefix_docids_sorter,
|
prefix_docids_sorter,
|
||||||
merge_roaring_bitmaps,
|
merge_roaring_bitmaps,
|
||||||
WriteMethod::GetMergePut,
|
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
@ -8,7 +8,7 @@ use slice_group_by::GroupBy;
|
|||||||
|
|
||||||
use crate::update::index_documents::{
|
use crate::update::index_documents::{
|
||||||
create_sorter, fst_stream_into_hashset, fst_stream_into_vec, merge_cbo_roaring_bitmaps,
|
create_sorter, fst_stream_into_hashset, fst_stream_into_vec, merge_cbo_roaring_bitmaps,
|
||||||
sorter_into_lmdb_database, CursorClonableMmap, MergeFn, WriteMethod,
|
sorter_into_lmdb_database, CursorClonableMmap, MergeFn,
|
||||||
};
|
};
|
||||||
use crate::{Index, Result, StrStrU8Codec};
|
use crate::{Index, Result, StrStrU8Codec};
|
||||||
|
|
||||||
@ -192,7 +192,6 @@ impl<'t, 'u, 'i> WordPrefixPairProximityDocids<'t, 'u, 'i> {
|
|||||||
*self.index.word_prefix_pair_proximity_docids.as_polymorph(),
|
*self.index.word_prefix_pair_proximity_docids.as_polymorph(),
|
||||||
word_prefix_pair_proximity_docids_sorter,
|
word_prefix_pair_proximity_docids_sorter,
|
||||||
merge_cbo_roaring_bitmaps,
|
merge_cbo_roaring_bitmaps,
|
||||||
WriteMethod::GetMergePut,
|
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
@ -14,7 +14,7 @@ use crate::heed_codec::StrBEU32Codec;
|
|||||||
use crate::index::main_key::WORDS_PREFIXES_FST_KEY;
|
use crate::index::main_key::WORDS_PREFIXES_FST_KEY;
|
||||||
use crate::update::index_documents::{
|
use crate::update::index_documents::{
|
||||||
create_sorter, fst_stream_into_hashset, fst_stream_into_vec, merge_cbo_roaring_bitmaps,
|
create_sorter, fst_stream_into_hashset, fst_stream_into_vec, merge_cbo_roaring_bitmaps,
|
||||||
sorter_into_lmdb_database, CursorClonableMmap, MergeFn, WriteMethod,
|
sorter_into_lmdb_database, CursorClonableMmap, MergeFn,
|
||||||
};
|
};
|
||||||
use crate::{Index, Result};
|
use crate::{Index, Result};
|
||||||
|
|
||||||
@ -170,7 +170,6 @@ impl<'t, 'u, 'i> WordPrefixPositionDocids<'t, 'u, 'i> {
|
|||||||
*self.index.word_prefix_position_docids.as_polymorph(),
|
*self.index.word_prefix_position_docids.as_polymorph(),
|
||||||
prefix_position_docids_sorter,
|
prefix_position_docids_sorter,
|
||||||
merge_cbo_roaring_bitmaps,
|
merge_cbo_roaring_bitmaps,
|
||||||
WriteMethod::GetMergePut,
|
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
Loading…
x
Reference in New Issue
Block a user