47 releases (15 breaking)

Uses new Rust 2024

new 0.16.0 Jul 8, 2025
0.14.1 Jun 1, 2025
0.12.0 Feb 25, 2025
0.11.0 Dec 10, 2024
0.2.0 Mar 7, 2021

#663 in Filesystem

Download history 4/week @ 2025-03-24 1/week @ 2025-03-31 3/week @ 2025-04-07 3/week @ 2025-04-14 1/week @ 2025-04-21 11/week @ 2025-05-05 203/week @ 2025-05-12 9/week @ 2025-05-19 201/week @ 2025-05-26 67/week @ 2025-06-02 2/week @ 2025-06-09 142/week @ 2025-06-23 9/week @ 2025-06-30 137/week @ 2025-07-07

288 downloads per month

WTFPL license

48KB
674 lines

Dowser

docs.rs changelog
crates.io ci deps.rs
license contributions welcome

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 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:

[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.

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();

Dependencies

~1MB
~18K SLoC