[−][src]Struct amadeus_core::par_sink::GroupBy
Implementations
impl<A, B> GroupBy<A, B>
[src]
Trait Implementations
impl<A: DistributedPipe<Source, Item = (T, U)>, B: DistributedSink<U>, Source, T, U> DistributedSink<Source> for GroupBy<A, B> where
T: Eq + Hash + ProcessSend + 'static,
<B::Pipe as DistributedPipe<U>>::Task: Clone + ProcessSend + 'static,
B::ReduceA: Clone + ProcessSend + 'static,
B::ReduceB: Clone,
B::ReduceC: Clone,
B::Output: ProcessSend + 'static,
[src]
T: Eq + Hash + ProcessSend + 'static,
<B::Pipe as DistributedPipe<U>>::Task: Clone + ProcessSend + 'static,
B::ReduceA: Clone + ProcessSend + 'static,
B::ReduceB: Clone,
B::ReduceC: Clone,
B::Output: ProcessSend + 'static,
type Output = HashMap<T, B::Output>
type Pipe = A
type ReduceA = GroupByReducerA<<B::Pipe as DistributedPipe<U>>::Task, B::ReduceA, T, U>
type ReduceB = GroupByReducerB<B::ReduceB, T, <B::ReduceA as ReducerSend<<B::Pipe as DistributedPipe<U>>::Item>>::Output>
type ReduceC = GroupByReducerB<B::ReduceC, T, <B::ReduceB as ReducerProcessSend<<B::ReduceA as Reducer<<B::Pipe as DistributedPipe<U>>::Item>>::Output>>::Output>
fn reducers(self) -> (Self::Pipe, Self::ReduceA, Self::ReduceB, Self::ReduceC)
[src]
impl<A: ParallelPipe<Source, Item = (T, U)>, B: ParallelSink<U>, Source, T, U> ParallelSink<Source> for GroupBy<A, B> where
T: Eq + Hash + Send + 'static,
<B::Pipe as ParallelPipe<U>>::Task: Clone + Send + 'static,
B::ReduceA: Clone + Send + 'static,
B::ReduceC: Clone,
B::Output: Send + 'static,
[src]
T: Eq + Hash + Send + 'static,
<B::Pipe as ParallelPipe<U>>::Task: Clone + Send + 'static,
B::ReduceA: Clone + Send + 'static,
B::ReduceC: Clone,
B::Output: Send + 'static,
type Output = HashMap<T, B::Output>
type Pipe = A
type ReduceA = GroupByReducerA<<B::Pipe as ParallelPipe<U>>::Task, B::ReduceA, T, U>
type ReduceC = GroupByReducerB<B::ReduceC, T, <B::ReduceA as ReducerSend<<B::Pipe as ParallelPipe<U>>::Item>>::Output>
fn reducers(self) -> (Self::Pipe, Self::ReduceA, Self::ReduceC)
[src]
Auto Trait Implementations
impl<A, B> RefUnwindSafe for GroupBy<A, B> where
A: RefUnwindSafe,
B: RefUnwindSafe,
A: RefUnwindSafe,
B: RefUnwindSafe,
impl<A, B> Send for GroupBy<A, B> where
A: Send,
B: Send,
A: Send,
B: Send,
impl<A, B> Sync for GroupBy<A, B> where
A: Sync,
B: Sync,
A: Sync,
B: Sync,
impl<A, B> Unpin for GroupBy<A, B> where
A: Unpin,
B: Unpin,
A: Unpin,
B: Unpin,
impl<A, B> UnwindSafe for GroupBy<A, B> where
A: UnwindSafe,
B: UnwindSafe,
A: UnwindSafe,
B: UnwindSafe,
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
V: MultiLane<T>,