[Dowser
] is a(nother) fast, multi-threaded, recursive file-finding library for Unix/Rust. It differs from Walkdir
and kin in a number of ways:
Vec<PathBuf>
;If those things sound nice, this library might be a good fit.
On the other hand, [Dowser
] is optimized for just one particular type of searching:
Dowser::filtered
] or [Dowser::regex
], but directory paths cannot;Depending on your needs, those limitations could be bad, in which case something like Walkdir
might make more sense.
Add dowser
to your dependencies
in Cargo.toml
, like:
[dependencies]
dowser = "0.2.*"
| Feature | Description |
| ------- | ----------- |
| regexp
| Enable the [Dowser::regex
] method, which allows for matching file paths (as bytes) against a regular expression. |
To use this feature, alter the Cargo.toml
bit to read:
[dependencies.dowser]
version = "0.2.*"
features = [ "regexp" ]
This crate comes with two ways to find files. If you already have the full list of starting path(s) and just want all the files that exist under them, use the dowse
method:
```rust use std::path::PathBuf;
let paths = [ "/path/one", "/path/two", "/path/three" ];
let files: Vec
If you want to filter files or need to add path(s) to the crawl list multiple times, initialize a [Dowser
] object with one of the following three methods:
Dowser::default
]: Return all files without prejudice.Dowser::filtered
]: Filter file paths via the provided callback.Dowser::regex
]: Filter file paths via regular express. (This requires enabling the regexp
crate feature.)From there, add one or more file or directory paths using the [Dowser::with_path
] and [Dowser::with_paths
] methods.
Finally, collect the results with Vec::<PathBuf>::try_from()
. If no files are found, an error is returned, otherwise the matching file paths are collected into a vector.
```rust use dowser::Dowser; use std::convert::TryFrom; use std::os::unix::ffi::OsStrExt; use std::path::{Path, PathBuf};
// Return all files under "/usr/share/man".
let files = Vec::
// Return only Gzipped files using regular expression.
let files = Vec::
// Return only Gzipped files using callback filter.
let files = Vec::
See also: CREDITS.md
Copyright © 2021 Blobfolio, LLC <hello@blobfolio.com>
This work is free. You can redistribute it and/or modify it under the terms of the Do What The Fuck You Want To Public License, Version 2.
DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE
Version 2, December 2004
Copyright (C) 2004 Sam Hocevar <sam@hocevar.net>
Everyone is permitted to copy and distribute verbatim or modified
copies of this license document, and changing it is allowed as long
as the name is changed.
DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
0. You just DO WHAT THE FUCK YOU WANT TO.