MeiliSearch/milli/src/search/new/logger/mod.rs

123 lines
3.4 KiB
Rust
Raw Normal View History

#[cfg(test)]
2023-02-22 15:34:37 +01:00
pub mod detailed;
use roaring::RoaringBitmap;
use super::{
ranking_rule_graph::{
empty_paths_cache::EmptyPathsCache, paths_map::PathsMap, proximity::ProximityGraph,
typo::TypoGraph, RankingRuleGraph,
},
2023-02-28 11:49:24 +01:00
RankingRule, RankingRuleQueryTrait,
};
2023-02-22 15:34:37 +01:00
pub struct DefaultSearchLogger;
impl<Q: RankingRuleQueryTrait> SearchLogger<Q> for DefaultSearchLogger {
2023-02-28 11:49:24 +01:00
fn initial_query(&mut self, _query: &Q) {}
2023-02-22 15:34:37 +01:00
2023-02-28 11:49:24 +01:00
fn initial_universe(&mut self, _universe: &RoaringBitmap) {}
2023-02-22 15:34:37 +01:00
fn ranking_rules(&mut self, _rr: &[&mut dyn RankingRule<Q>]) {}
2023-02-22 15:34:37 +01:00
fn start_iteration_ranking_rule<'transaction>(
&mut self,
2023-02-28 11:49:24 +01:00
_ranking_rule_idx: usize,
_ranking_rule: &dyn RankingRule<'transaction, Q>,
_query: &Q,
_universe: &RoaringBitmap,
2023-02-22 15:34:37 +01:00
) {
}
fn next_bucket_ranking_rule<'transaction>(
&mut self,
2023-02-28 11:49:24 +01:00
_ranking_rule_idx: usize,
_ranking_rule: &dyn RankingRule<'transaction, Q>,
_universe: &RoaringBitmap,
2023-02-22 15:34:37 +01:00
) {
}
fn skip_bucket_ranking_rule<'transaction>(
&mut self,
2023-02-28 11:49:24 +01:00
_ranking_rule_idx: usize,
_ranking_rule: &dyn RankingRule<'transaction, Q>,
_candidates: &RoaringBitmap,
) {
}
2023-02-22 15:34:37 +01:00
fn end_iteration_ranking_rule<'transaction>(
&mut self,
2023-02-28 11:49:24 +01:00
_ranking_rule_idx: usize,
_ranking_rule: &dyn RankingRule<'transaction, Q>,
_universe: &RoaringBitmap,
2023-02-22 15:34:37 +01:00
) {
}
2023-02-28 11:49:24 +01:00
fn add_to_results(&mut self, _docids: &[u32]) {}
2023-02-22 15:34:37 +01:00
2023-02-28 11:49:24 +01:00
fn log_words_state(&mut self, _query_graph: &Q) {}
fn log_proximity_state(
&mut self,
2023-02-28 11:49:24 +01:00
_query_graph: &RankingRuleGraph<ProximityGraph>,
_paths_map: &PathsMap<u64>,
_empty_paths_cache: &EmptyPathsCache,
) {
}
fn log_typo_state(
&mut self,
query_graph: &RankingRuleGraph<TypoGraph>,
paths: &PathsMap<u64>,
empty_paths_cache: &EmptyPathsCache,
) {
}
2023-02-22 15:34:37 +01:00
}
pub trait SearchLogger<Q: RankingRuleQueryTrait> {
fn initial_query(&mut self, query: &Q);
fn initial_universe(&mut self, universe: &RoaringBitmap);
fn ranking_rules(&mut self, rr: &[&mut dyn RankingRule<Q>]);
2023-02-22 15:34:37 +01:00
fn start_iteration_ranking_rule<'transaction>(
&mut self,
ranking_rule_idx: usize,
ranking_rule: &dyn RankingRule<'transaction, Q>,
query: &Q,
universe: &RoaringBitmap,
);
fn next_bucket_ranking_rule<'transaction>(
&mut self,
ranking_rule_idx: usize,
ranking_rule: &dyn RankingRule<'transaction, Q>,
universe: &RoaringBitmap,
);
fn skip_bucket_ranking_rule<'transaction>(
&mut self,
ranking_rule_idx: usize,
ranking_rule: &dyn RankingRule<'transaction, Q>,
candidates: &RoaringBitmap,
);
2023-02-22 15:34:37 +01:00
fn end_iteration_ranking_rule<'transaction>(
&mut self,
ranking_rule_idx: usize,
ranking_rule: &dyn RankingRule<'transaction, Q>,
universe: &RoaringBitmap,
);
fn add_to_results(&mut self, docids: &[u32]);
2023-02-22 15:34:37 +01:00
fn log_words_state(&mut self, query_graph: &Q);
fn log_proximity_state(
&mut self,
query_graph: &RankingRuleGraph<ProximityGraph>,
paths: &PathsMap<u64>,
empty_paths_cache: &EmptyPathsCache,
);
fn log_typo_state(
&mut self,
query_graph: &RankingRuleGraph<TypoGraph>,
paths: &PathsMap<u64>,
empty_paths_cache: &EmptyPathsCache,
);
2023-02-22 15:34:37 +01:00
}