Dowser
is a(nother) fast, recursive file-finding library for Unix/Rust. It differs from Walkdir
and kin in a number of ways:
- It is not limited to one root; any number of file and directory paths can be loaded and traversed en masse;
- Symlinks and hidden directories are followed like any other, including across devices;
- Matching file paths are canonicalized and deduped before yielding;
If those things sound nice, this library might be a good fit.
On the other hand, Dowser
is optimized for file searching; the iterator crawls but does not yield directory paths, which could be bad if you need those too. Haha.
Add dowser
to your dependencies
in Cargo.toml
, like:
[dependencies]
dowser = "0.11.*"
All you need to do is chain Dowser::default
with one or more of the following seed methods:
Dowser::with_path
/Dowser::with_paths
Dowser::without_path
/Dowser::without_paths
From there, you can apply any Iterator
methods you want, or immediately collect the results using Dowser::into_vec
or Dowser::into_vec_filtered
.
use dowser::Dowser;
use std::path::PathBuf;
// Return all files under "/usr/share/man".
let files1: Vec::<PathBuf> = Dowser::default()
.with_path("/usr/share/man")
.collect();
// Same as above, but slightly faster.
let files2: Vec::<PathBuf> = Dowser::default()
.with_path("/usr/share/man")
.into_vec();
assert_eq!(files1.len(), files2.len());
// Return only Gzipped files using callback filter.
let files1: Vec::<PathBuf> = Dowser::default()
.with_path("/usr/share/man")
.filter(|p|
p.extension().is_some_and(|e| e.eq_ignore_ascii_case("gz"))
)
.collect();
// Same as above, but slightly faster.
let files2: Vec::<PathBuf> = Dowser::default()
.with_path("/usr/share/man")
.into_vec_filtered(|p|
p.extension().is_some_and(|e| e.eq_ignore_ascii_case("gz"))
);
assert_eq!(files1.len(), files2.len());