crop skeleton

This commit is contained in:
Marin Postma
2021-05-05 17:31:40 +02:00
committed by Clémentine Urquizar
parent 5795254b2a
commit 7904637893

View File

@@ -232,7 +232,8 @@ fn compute_formatted<A: AsRef<[u8]>>(
highlighter: &Highlighter<A>, highlighter: &Highlighter<A>,
matching_words: &impl Matcher, matching_words: &impl Matcher,
all_formatted: &[FieldId], all_formatted: &[FieldId],
to_highlight_ids: &HashSet<FieldId>, to_highlight_fields: &HashSet<FieldId>,
to_crop_fields: &HashSet<FieldId>,
) -> anyhow::Result<Document> { ) -> anyhow::Result<Document> {
let mut document = Document::new(); let mut document = Document::new();
@@ -240,8 +241,8 @@ fn compute_formatted<A: AsRef<[u8]>>(
if let Some(value) = obkv.get(*field) { if let Some(value) = obkv.get(*field) {
let mut value: Value = serde_json::from_slice(value)?; let mut value: Value = serde_json::from_slice(value)?;
if to_highlight_ids.contains(field) { if to_highlight_fields.contains(field) {
value = highlighter.highlight_value(value, matching_words); value = highlighter.format_value(value, matching_words, to_highlight_fields.contains(field));
} }
// This unwrap must be safe since we got the ids from the fields_ids_map just // This unwrap must be safe since we got the ids from the fields_ids_map just
@@ -291,46 +292,55 @@ impl<'a, A: AsRef<[u8]>> Highlighter<'a, A> {
Self { analyzer, marks } Self { analyzer, marks }
} }
fn highlight_value(&self, value: Value, words_to_highlight: &impl Matcher) -> Value { fn format_value(
&self,
value: Value,
matcher: &impl Matcher,
need_to_crop: Option<u32>,
need_to_highlight: bool,
) -> Value {
match value { match value {
Value::Null => Value::Null,
Value::Bool(boolean) => Value::Bool(boolean),
Value::Number(number) => Value::Number(number),
Value::String(old_string) => { Value::String(old_string) => {
let mut string = String::new(); let value = self.format_string(old_string, need_to_crop, need_to_highlight);
let analyzed = self.analyzer.analyze(&old_string); Value::String(value)
for (word, token) in analyzed.reconstruct() {
if token.is_word() {
let to_highlight = words_to_highlight.matches(token.text());
if to_highlight {
string.push_str(&self.marks.0)
}
string.push_str(word);
if to_highlight {
string.push_str(&self.marks.1)
}
} else {
string.push_str(word);
}
}
Value::String(string)
} }
Value::Array(values) => Value::Array( Value::Array(values) => Value::Array(
values values
.into_iter() .into_iter()
.map(|v| self.highlight_value(v, words_to_highlight)) .map(|v| self.format_value(v, matcher, None, need_to_highlight))
.collect(), .collect(),
), ),
Value::Object(object) => Value::Object( Value::Object(object) => Value::Object(
object object
.into_iter() .into_iter()
.map(|(k, v)| (k, self.highlight_value(v, words_to_highlight))) .map(|(k, v)| (k, self.format_value(value, matcher, None, need_to_highlight)))
.collect(), .collect(),
), ),
value => value,
} }
} }
fn format_string(&self, s: String, need_to_crop: Option<u32>, need_to_highlight: bool) -> String {
let word_iter: Box<dyn Iterator<Item = (String, bool)>> = if let Some(_crop_len) = need_to_crop {
// cropping iterator
todo!()
} else {
// normal Iterator
todo!()
};
word_iter.map(|(word, is_match)| {
if need_to_highlight && is_match {
// highlight word
todo!()
} else {
word
}
})
.collect::<String>()
}
} }
fn parse_facets( fn parse_facets(
facets: &Value, facets: &Value,
index: &Index, index: &Index,