# Dowser
[](https://docs.rs/dowser/)
[](https://github.com/Blobfolio/dowser/blob/master/CHANGELOG.md)<br>
[](https://crates.io/crates/dowser)
[](https://github.com/Blobfolio/dowser/actions)
[](https://deps.rs/crate/dowser/)<br>
[](https://en.wikipedia.org/wiki/WTFPL)
[](https://github.com/Blobfolio/dowser/issues)
`Dowser` is a(nother) fast, recursive file-finding library for Unix/Rust. It differs from [`Walkdir`](https://crates.io/crates/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 are followed by default, but can be disabled using `Dowser::without_symlinks`;
* Hidden paths and mount points are traversed like anything else;
* 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.
## Installation
Add `dowser` to your `dependencies` in `Cargo.toml`, like:
```toml
[dependencies]
dowser = "0.16.*"
```
## Example
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.
```rust
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();
// 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();
```