mirror of
https://github.com/meilisearch/meilisearch.git
synced 2024-11-22 18:17:39 +08:00
chore: Move Streams to map file
This commit is contained in:
parent
593758c6d2
commit
33801f1d23
94
src/lib.rs
94
src/lib.rs
@ -3,102 +3,10 @@ extern crate bincode;
|
|||||||
extern crate fst;
|
extern crate fst;
|
||||||
extern crate serde;
|
extern crate serde;
|
||||||
|
|
||||||
mod map;
|
pub mod map;
|
||||||
|
|
||||||
use fst::Automaton;
|
|
||||||
|
|
||||||
pub use self::map::{Map, MapBuilder, Values};
|
pub use self::map::{Map, MapBuilder, Values};
|
||||||
pub use self::map::{
|
pub use self::map::{
|
||||||
OpBuilder, IndexedValues,
|
OpBuilder, IndexedValues,
|
||||||
OpWithStateBuilder, IndexedValuesWithState,
|
OpWithStateBuilder, IndexedValuesWithState,
|
||||||
};
|
};
|
||||||
|
|
||||||
pub struct StreamBuilder<'m, 'v, T: 'v, A> {
|
|
||||||
inner: fst::map::StreamBuilder<'m, A>,
|
|
||||||
values: &'v Values<T>,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<'m, 'v, T: 'v, A> StreamBuilder<'m, 'v, T, A> {
|
|
||||||
pub fn with_state(self) -> StreamWithStateBuilder<'m, 'v, T, A> {
|
|
||||||
StreamWithStateBuilder {
|
|
||||||
inner: self.inner.with_state(),
|
|
||||||
values: self.values,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<'m, 'v, 'a, T: 'v + 'a, A: Automaton> fst::IntoStreamer<'a> for StreamBuilder<'m, 'v, T, A> {
|
|
||||||
type Item = <Self::Into as fst::Streamer<'a>>::Item;
|
|
||||||
type Into = Stream<'m, 'v, T, A>;
|
|
||||||
|
|
||||||
fn into_stream(self) -> Self::Into {
|
|
||||||
Stream {
|
|
||||||
inner: self.inner.into_stream(),
|
|
||||||
values: self.values,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub struct Stream<'m, 'v, T: 'v, A: Automaton = fst::automaton::AlwaysMatch> {
|
|
||||||
inner: fst::map::Stream<'m, A>,
|
|
||||||
values: &'v Values<T>,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<'m, 'v, 'a, T: 'v + 'a, A: Automaton> fst::Streamer<'a> for Stream<'m, 'v, T, A> {
|
|
||||||
type Item = (&'a [u8], &'a [T]);
|
|
||||||
|
|
||||||
fn next(&'a mut self) -> Option<Self::Item> {
|
|
||||||
// Here we can't just `map` because of some borrow rules
|
|
||||||
match self.inner.next() {
|
|
||||||
Some((key, i)) => {
|
|
||||||
let values = unsafe { self.values.get_unchecked(i as usize) };
|
|
||||||
Some((key, values))
|
|
||||||
},
|
|
||||||
None => None,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub struct StreamWithStateBuilder<'m, 'v, T: 'v, A> {
|
|
||||||
inner: fst::map::StreamWithStateBuilder<'m, A>,
|
|
||||||
values: &'v Values<T>,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<'m, 'v, 'a, T: 'v + 'a, A: 'a> fst::IntoStreamer<'a> for StreamWithStateBuilder<'m, 'v, T, A>
|
|
||||||
where
|
|
||||||
A: Automaton,
|
|
||||||
A::State: Clone,
|
|
||||||
{
|
|
||||||
type Item = <Self::Into as fst::Streamer<'a>>::Item;
|
|
||||||
type Into = StreamWithState<'m, 'v, T, A>;
|
|
||||||
|
|
||||||
fn into_stream(self) -> Self::Into {
|
|
||||||
StreamWithState {
|
|
||||||
inner: self.inner.into_stream(),
|
|
||||||
values: self.values,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub struct StreamWithState<'m, 'v, T: 'v, A: Automaton = fst::automaton::AlwaysMatch> {
|
|
||||||
inner: fst::map::StreamWithState<'m, A>,
|
|
||||||
values: &'v Values<T>,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<'m, 'v, 'a, T: 'v + 'a, A: 'a> fst::Streamer<'a> for StreamWithState<'m, 'v, T, A>
|
|
||||||
where
|
|
||||||
A: Automaton,
|
|
||||||
A::State: Clone,
|
|
||||||
{
|
|
||||||
type Item = (&'a [u8], &'a [T], A::State);
|
|
||||||
|
|
||||||
fn next(&'a mut self) -> Option<Self::Item> {
|
|
||||||
match self.inner.next() {
|
|
||||||
Some((key, i, state)) => {
|
|
||||||
let values = unsafe { self.values.get_unchecked(i as usize) };
|
|
||||||
Some((key, values, state))
|
|
||||||
},
|
|
||||||
None => None,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
91
src/map.rs
91
src/map.rs
@ -6,7 +6,6 @@ use std::fs::File;
|
|||||||
use std::io::{Write, BufReader};
|
use std::io::{Write, BufReader};
|
||||||
use std::ops::Range;
|
use std::ops::Range;
|
||||||
use std::path::Path;
|
use std::path::Path;
|
||||||
use {StreamBuilder, Stream};
|
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub struct Map<T> {
|
pub struct Map<T> {
|
||||||
@ -312,3 +311,93 @@ pub struct IndexedValuesWithState<'a, T: 'a, U> {
|
|||||||
pub values: &'a [T],
|
pub values: &'a [T],
|
||||||
pub state: U,
|
pub state: U,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub struct StreamBuilder<'m, 'v, T: 'v, A> {
|
||||||
|
inner: fst::map::StreamBuilder<'m, A>,
|
||||||
|
values: &'v Values<T>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'m, 'v, T: 'v, A> StreamBuilder<'m, 'v, T, A> {
|
||||||
|
pub fn with_state(self) -> StreamWithStateBuilder<'m, 'v, T, A> {
|
||||||
|
StreamWithStateBuilder {
|
||||||
|
inner: self.inner.with_state(),
|
||||||
|
values: self.values,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'m, 'v, 'a, T: 'v + 'a, A: Automaton> fst::IntoStreamer<'a> for StreamBuilder<'m, 'v, T, A> {
|
||||||
|
type Item = <Self::Into as fst::Streamer<'a>>::Item;
|
||||||
|
type Into = Stream<'m, 'v, T, A>;
|
||||||
|
|
||||||
|
fn into_stream(self) -> Self::Into {
|
||||||
|
Stream {
|
||||||
|
inner: self.inner.into_stream(),
|
||||||
|
values: self.values,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct Stream<'m, 'v, T: 'v, A: Automaton = fst::automaton::AlwaysMatch> {
|
||||||
|
inner: fst::map::Stream<'m, A>,
|
||||||
|
values: &'v Values<T>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'m, 'v, 'a, T: 'v + 'a, A: Automaton> fst::Streamer<'a> for Stream<'m, 'v, T, A> {
|
||||||
|
type Item = (&'a [u8], &'a [T]);
|
||||||
|
|
||||||
|
fn next(&'a mut self) -> Option<Self::Item> {
|
||||||
|
// Here we can't just `map` because of some borrow rules
|
||||||
|
match self.inner.next() {
|
||||||
|
Some((key, i)) => {
|
||||||
|
let values = unsafe { self.values.get_unchecked(i as usize) };
|
||||||
|
Some((key, values))
|
||||||
|
},
|
||||||
|
None => None,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct StreamWithStateBuilder<'m, 'v, T: 'v, A> {
|
||||||
|
inner: fst::map::StreamWithStateBuilder<'m, A>,
|
||||||
|
values: &'v Values<T>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'m, 'v, 'a, T: 'v + 'a, A: 'a> fst::IntoStreamer<'a> for StreamWithStateBuilder<'m, 'v, T, A>
|
||||||
|
where
|
||||||
|
A: Automaton,
|
||||||
|
A::State: Clone,
|
||||||
|
{
|
||||||
|
type Item = <Self::Into as fst::Streamer<'a>>::Item;
|
||||||
|
type Into = StreamWithState<'m, 'v, T, A>;
|
||||||
|
|
||||||
|
fn into_stream(self) -> Self::Into {
|
||||||
|
StreamWithState {
|
||||||
|
inner: self.inner.into_stream(),
|
||||||
|
values: self.values,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct StreamWithState<'m, 'v, T: 'v, A: Automaton = fst::automaton::AlwaysMatch> {
|
||||||
|
inner: fst::map::StreamWithState<'m, A>,
|
||||||
|
values: &'v Values<T>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'m, 'v, 'a, T: 'v + 'a, A: 'a> fst::Streamer<'a> for StreamWithState<'m, 'v, T, A>
|
||||||
|
where
|
||||||
|
A: Automaton,
|
||||||
|
A::State: Clone,
|
||||||
|
{
|
||||||
|
type Item = (&'a [u8], &'a [T], A::State);
|
||||||
|
|
||||||
|
fn next(&'a mut self) -> Option<Self::Item> {
|
||||||
|
match self.inner.next() {
|
||||||
|
Some((key, i, state)) => {
|
||||||
|
let values = unsafe { self.values.get_unchecked(i as usize) };
|
||||||
|
Some((key, values, state))
|
||||||
|
},
|
||||||
|
None => None,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user