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
use super::DataTree;
use crate::size::Size;
use rayon::prelude::*;
use std::cmp::Ordering;
impl<Name, Data> DataTree<Name, Data>
where
Self: Send,
Data: Size,
{
pub fn par_sort_by(&mut self, compare: impl Fn(&Self, &Self) -> Ordering + Copy + Sync) {
self.children
.par_iter_mut()
.for_each(|child| child.par_sort_by(compare));
self.children.sort_by(compare);
}
pub fn into_par_sorted(
mut self,
compare: impl Fn(&Self, &Self) -> Ordering + Copy + Sync,
) -> Self {
self.par_sort_by(compare);
self
}
}