mirror of
https://github.com/meilisearch/MeiliSearch
synced 2024-11-26 23:04:26 +01:00
Use an ugly trick to avoid cloning the FST
This commit is contained in:
parent
1163f390b3
commit
4be11f961b
@ -446,7 +446,7 @@ fn fetch_matches<'txn, 'tag>(
|
|||||||
) -> MResult<Vec<BareMatch<'tag>>>
|
) -> MResult<Vec<BareMatch<'tag>>>
|
||||||
{
|
{
|
||||||
let before_words_fst = Instant::now();
|
let before_words_fst = Instant::now();
|
||||||
let words = match main_store.words_fst(reader)? {
|
let words = match unsafe { main_store.static_words_fst(reader)? } {
|
||||||
Some(words) => words,
|
Some(words) => words,
|
||||||
None => return Ok(Vec::new()),
|
None => return Ok(Vec::new()),
|
||||||
};
|
};
|
||||||
|
@ -67,6 +67,17 @@ impl Main {
|
|||||||
self.main.put::<_, Str, ByteSlice>(writer, WORDS_KEY, bytes)
|
self.main.put::<_, Str, ByteSlice>(writer, WORDS_KEY, bytes)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub unsafe fn static_words_fst(self, reader: &heed::RoTxn<MainT>) -> ZResult<Option<fst::Set>> {
|
||||||
|
match self.main.get::<_, Str, ByteSlice>(reader, WORDS_KEY)? {
|
||||||
|
Some(bytes) => {
|
||||||
|
let bytes: &'static [u8] = std::mem::transmute(bytes);
|
||||||
|
let set = fst::Set::from_static_slice(bytes).unwrap();
|
||||||
|
Ok(Some(set))
|
||||||
|
}
|
||||||
|
None => Ok(None),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn words_fst(self, reader: &heed::RoTxn<MainT>) -> ZResult<Option<fst::Set>> {
|
pub fn words_fst(self, reader: &heed::RoTxn<MainT>) -> ZResult<Option<fst::Set>> {
|
||||||
match self.main.get::<_, Str, ByteSlice>(reader, WORDS_KEY)? {
|
match self.main.get::<_, Str, ByteSlice>(reader, WORDS_KEY)? {
|
||||||
Some(bytes) => {
|
Some(bytes) => {
|
||||||
|
Loading…
Reference in New Issue
Block a user