Remove, now useless, the WriteMethod enum

This commit is contained in:
Clément Renault 2022-01-25 17:12:12 +01:00 committed by Kerollmops
parent e9c02173cf
commit 51d1e64b23
No known key found for this signature in database
GPG Key ID: 92ADA4E935E71FA4
6 changed files with 28 additions and 67 deletions

View File

@ -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,
)?; )?;
} }

View File

@ -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)?;
}
}
} }
} }
} }

View File

@ -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,

View File

@ -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(())

View File

@ -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(())

View File

@ -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(())