3 mod convenience_operators {
4 use crate::{Op, Relation};
5 use std::ops::AddAssign;
8 impl<C: Op> Relation<C> {
9 pub fn map<F: Fn(C::D) -> D2 + 'static, D2: 'static>(
12 ) -> Relation<impl Op<D = D2, R = C::R>> {
13 self.map_dr(move |x, r| (f(x), r))
17 impl<K: 'static, V: 'static, C: Op<D = (K, V)>> Relation<C> {
18 pub fn semijoin<C2: Op<D = K, R = R2>, R2, R3: AddAssign<R3>>(
21 ) -> Relation<impl Op<D = C::D, R = R3>>
23 C::R: Mul<R2, Output = R3>,
25 self.join(other.map(|x| (x, ()))).map(|(k, x, ())| (k, x))
34 use crate::core::Relation;
35 use std::ops::{AddAssign, Mul};
41 LC: Op<D = (K, LD), R = LR>,
42 RC: Op<D = (K, RD), R = RR>,
45 LR: AddAssign<LR> + Mul<RR, Output = OR>,
54 impl<K: 'static, D: 'static, C: Op<D = (K, D)>> Relation<C> {
55 pub fn join<C2: Op<D = (K, D2)>, D2: 'static, OR: AddAssign<OR>>(
58 ) -> Relation<impl Op<D = (K, D, D2), R = OR>>
60 C::R: Mul<C2::R, Output = OR>,
73 use crate::core::Relation;
74 use std::ops::AddAssign;
84 C: Op<D = D1, R = R1>,
85 MF: Fn(D1, R1) -> (D2, R2),
91 impl<C: Op> Relation<C> {
92 pub fn map_dr<F: Fn(C::D, C::R) -> (D2, R2), D2: 'static, R2: AddAssign<R2>>(
95 ) -> Relation<impl Op<D = D2, R = R2>> {
105 use std::ops::AddAssign;
108 type R: AddAssign<Self::R>;
111 pub use self::operator::Op;
113 pub struct Relation<C> {
119 pub use self::core::Relation;