parallel_disk_usage/
tree_builder.rspub mod info;
pub use info::Info;
use super::{data_tree::DataTree, size};
use rayon::prelude::*;
#[derive(Debug)]
pub struct TreeBuilder<Path, Name, Size, GetInfo, JoinPath>
where
Path: Send + Sync,
Name: Send + Sync,
GetInfo: Fn(&Path) -> Info<Name, Size> + Copy + Send + Sync,
JoinPath: Fn(&Path, &Name) -> Path + Copy + Send + Sync,
Size: size::Size + Send,
{
pub path: Path,
pub name: Name,
pub get_info: GetInfo,
pub join_path: JoinPath,
}
impl<Path, Name, Size, GetInfo, JoinPath> From<TreeBuilder<Path, Name, Size, GetInfo, JoinPath>>
for DataTree<Name, Size>
where
Path: Send + Sync,
Name: Send + Sync,
GetInfo: Fn(&Path) -> Info<Name, Size> + Copy + Send + Sync,
JoinPath: Fn(&Path, &Name) -> Path + Copy + Send + Sync,
Size: size::Size + Send,
{
fn from(builder: TreeBuilder<Path, Name, Size, GetInfo, JoinPath>) -> Self {
let TreeBuilder {
path,
name,
get_info,
join_path,
} = builder;
let Info { size, children } = get_info(&path);
let children: Vec<_> = children
.into_par_iter()
.map(|name| TreeBuilder {
path: join_path(&path, &name),
name,
get_info,
join_path,
})
.map(Self::from)
.collect();
DataTree::dir(name, size, children)
}
}