1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
use crate::core::{relation::RelationInner, Op_, Relation};
pub struct FlatMap<C: Op_, I: IntoIterator, F: Fn(C::T) -> I> {
inner: RelationInner<C>,
f: F,
}
impl<C: Op_, I: IntoIterator, F: Fn(C::T) -> I> Op_ for FlatMap<C, I, F> {
type T = I::Item;
fn foreach<'a>(&'a mut self, mut continuation: impl FnMut(Self::T) + 'a) {
let FlatMap { inner, f } = self;
inner.foreach(|x| {
for y in f(x) {
continuation(y)
}
})
}
fn get_type_name() -> &'static str {
"flat_map"
}
}
impl<C: Op_> Relation<C> {
pub fn flat_map_<I: IntoIterator, F: Fn(C::T) -> I>(self, f: F) -> Relation<FlatMap<C, I, F>> {
self.context_tracker.add_relation(
self.dirty,
FlatMap {
inner: self.inner,
f,
},
vec![self.tracking_index],
)
}
}