4 releases (2 stable)

2.0.0 Jun 16, 2024
1.0.0 Jan 4, 2024
0.2.0 Sep 7, 2020
0.1.0 Aug 31, 2020

#115 in Asynchronous

Download history 10454/week @ 2024-09-21 10192/week @ 2024-09-28 12268/week @ 2024-10-05 9144/week @ 2024-10-12 10714/week @ 2024-10-19 8265/week @ 2024-10-26 8950/week @ 2024-11-02 10773/week @ 2024-11-09 11587/week @ 2024-11-16 12470/week @ 2024-11-23 15059/week @ 2024-11-30 13968/week @ 2024-12-07 14004/week @ 2024-12-14 7437/week @ 2024-12-21 7822/week @ 2024-12-28 12457/week @ 2025-01-04

43,309 downloads per month
Used in 35 crates (16 directly)

Apache-2.0

19KB
338 lines

Github CI docs.rs

async-walkdir

Asynchronous directory traversal for Rust.

Based on async-fs and blocking, it uses a thread pool to handle blocking IOs. Please refere to those crates for the rationale. This crate is compatible with async runtimes tokio, async-std, smol and potentially any runtime based on futures 0.3

We do not plan to be as feature full as Walkdir crate in the synchronous world, but do not hesitate to open an issue or a PR.

Example

use async_walkdir::WalkDir;
use futures_lite::future::block_on;
use futures_lite::stream::StreamExt;

block_on(async {
    let mut entries = WalkDir::new("my_directory");
    loop {
        match entries.next().await {
            Some(Ok(entry)) => println!("file: {}", entry.path().display()),
            Some(Err(e)) => {
                eprintln!("error: {}", e);
                break;
            },
            None => break,
        }
    }
});

Dependencies

~1.3–1.8MB
~33K SLoC