2019-10-08 21:22:36 +08:00
|
|
|
#[cfg(test)]
|
2019-10-18 19:05:28 +08:00
|
|
|
#[macro_use]
|
|
|
|
extern crate assert_matches;
|
2019-10-08 21:22:36 +08:00
|
|
|
|
2019-10-02 23:34:32 +08:00
|
|
|
mod automaton;
|
2019-12-13 18:49:56 +08:00
|
|
|
mod bucket_sort;
|
2019-10-04 22:49:17 +08:00
|
|
|
mod database;
|
2019-10-09 19:44:18 +08:00
|
|
|
mod distinct_map;
|
2019-10-03 21:04:11 +08:00
|
|
|
mod error;
|
2019-10-31 00:25:42 +08:00
|
|
|
mod levenshtein;
|
2019-10-03 17:49:13 +08:00
|
|
|
mod number;
|
2019-10-02 23:34:32 +08:00
|
|
|
mod query_builder;
|
2019-10-03 21:04:11 +08:00
|
|
|
mod ranked_map;
|
2019-10-02 23:34:32 +08:00
|
|
|
mod raw_document;
|
2019-10-18 19:05:28 +08:00
|
|
|
mod reordered_attrs;
|
2019-12-13 18:49:56 +08:00
|
|
|
mod update;
|
|
|
|
pub mod criterion;
|
|
|
|
pub mod raw_indexer;
|
2019-10-03 17:49:13 +08:00
|
|
|
pub mod serde;
|
2019-10-02 23:34:32 +08:00
|
|
|
pub mod store;
|
2019-11-30 23:53:34 +08:00
|
|
|
|
2019-11-26 23:12:06 +08:00
|
|
|
pub use self::database::{BoxUpdateFn, Database, MainT, UpdateT};
|
2019-10-03 23:33:15 +08:00
|
|
|
pub use self::error::{Error, MResult};
|
2019-10-04 19:26:33 +08:00
|
|
|
pub use self::number::{Number, ParseNumberError};
|
|
|
|
pub use self::ranked_map::RankedMap;
|
2019-10-04 22:49:17 +08:00
|
|
|
pub use self::raw_document::RawDocument;
|
2019-10-04 19:26:33 +08:00
|
|
|
pub use self::store::Index;
|
2019-10-31 18:13:37 +08:00
|
|
|
pub use self::update::{EnqueuedUpdateResult, ProcessedUpdateResult, UpdateStatus, UpdateType};
|
2019-12-13 18:46:53 +08:00
|
|
|
pub use meilisearch_types::{DocIndex, DocumentId, Highlight};
|
2019-10-02 23:34:32 +08:00
|
|
|
|
2019-12-12 00:36:53 +08:00
|
|
|
use compact_arena::SmallArena;
|
|
|
|
use crate::bucket_sort::{QueryWordAutomaton, PostingsListView};
|
|
|
|
use crate::levenshtein::prefix_damerau_levenshtein;
|
|
|
|
|
2019-12-13 18:14:12 +08:00
|
|
|
#[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord)]
|
2019-10-02 23:34:32 +08:00
|
|
|
pub struct Document {
|
|
|
|
pub id: DocumentId,
|
|
|
|
pub highlights: Vec<Highlight>,
|
|
|
|
|
2019-12-13 18:14:12 +08:00
|
|
|
#[cfg(test)]
|
|
|
|
pub matches: Vec<crate::bucket_sort::SimpleMatch>,
|
2019-10-02 23:34:32 +08:00
|
|
|
}
|
|
|
|
|
2019-12-12 00:36:53 +08:00
|
|
|
impl Document {
|
|
|
|
pub fn from_raw<'a, 'tag, 'txn>(
|
|
|
|
raw_document: RawDocument<'a, 'tag>,
|
|
|
|
automatons: &[QueryWordAutomaton],
|
|
|
|
arena: &SmallArena<'tag, PostingsListView<'txn>>,
|
|
|
|
) -> Document
|
|
|
|
{
|
2019-12-13 19:38:54 +08:00
|
|
|
let highlights = raw_document.bare_matches.iter().flat_map(|sm| {
|
2019-12-12 00:36:53 +08:00
|
|
|
let postings_list = &arena[sm.postings_list];
|
|
|
|
let input = postings_list.input();
|
|
|
|
let query = &automatons[sm.query_index as usize].query;
|
|
|
|
postings_list.iter().map(move |m| {
|
|
|
|
let covered_area = if query.len() > input.len() {
|
|
|
|
input.len()
|
|
|
|
} else {
|
|
|
|
prefix_damerau_levenshtein(query.as_bytes(), input).1
|
|
|
|
};
|
|
|
|
|
|
|
|
Highlight {
|
|
|
|
attribute: m.attribute,
|
|
|
|
char_index: m.char_index,
|
|
|
|
char_length: covered_area as u16,
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}).collect();
|
|
|
|
|
2019-12-13 18:14:12 +08:00
|
|
|
#[cfg(not(test))]
|
|
|
|
{
|
|
|
|
Document { id: raw_document.id, highlights }
|
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
{
|
|
|
|
let matches = raw_document.processed_matches;
|
|
|
|
Document { id: raw_document.id, highlights, matches }
|
|
|
|
}
|
2019-12-12 00:36:53 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-10-02 23:34:32 +08:00
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
use super::*;
|
|
|
|
use std::mem;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn docindex_mem_size() {
|
|
|
|
assert_eq!(mem::size_of::<DocIndex>(), 16);
|
|
|
|
}
|
|
|
|
}
|