mirror of
https://github.com/meilisearch/MeiliSearch
synced 2024-11-27 07:14:26 +01:00
46 lines
1.3 KiB
Rust
46 lines
1.3 KiB
Rust
use std::error::Error;
|
|
|
|
use byteorder::{ReadBytesExt, WriteBytesExt};
|
|
|
|
use meilidb_core::{Index as WordIndex};
|
|
use meilidb_core::data::DocIds;
|
|
use meilidb_core::write_to_bytes::WriteToBytes;
|
|
use meilidb_core::shared_data_cursor::{SharedDataCursor, FromSharedDataCursor};
|
|
|
|
enum NewIndexEvent<'a> {
|
|
RemovedDocuments(&'a DocIds),
|
|
UpdatedDocuments(&'a WordIndex),
|
|
}
|
|
|
|
impl<'a> WriteToBytes for NewIndexEvent<'a> {
|
|
fn write_to_bytes(&self, bytes: &mut Vec<u8>) {
|
|
match self {
|
|
NewIndexEvent::RemovedDocuments(doc_ids) => {
|
|
let _ = bytes.write_u8(0);
|
|
doc_ids.write_to_bytes(bytes);
|
|
},
|
|
NewIndexEvent::UpdatedDocuments(index) => {
|
|
let _ = bytes.write_u8(1);
|
|
index.write_to_bytes(bytes);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
enum IndexEvent {
|
|
RemovedDocuments(DocIds),
|
|
UpdatedDocuments(WordIndex),
|
|
}
|
|
|
|
impl FromSharedDataCursor for IndexEvent {
|
|
type Error = Box<Error>;
|
|
|
|
fn from_shared_data_cursor(cursor: &mut SharedDataCursor) -> Result<Self, Self::Error> {
|
|
match cursor.read_u8()? {
|
|
0 => DocIds::from_shared_data_cursor(cursor).map(IndexEvent::RemovedDocuments),
|
|
1 => WordIndex::from_shared_data_cursor(cursor).map(IndexEvent::UpdatedDocuments),
|
|
_ => Err("invalid index event type".into()),
|
|
}
|
|
}
|
|
}
|