5 unstable releases

new 0.3.0 May 17, 2024
0.2.1 Mar 30, 2024
0.2.0 Sep 19, 2023
0.1.1 Jun 24, 2023
0.1.0 Jun 24, 2023

#1131 in Filesystem

Download history 26/week @ 2024-02-16 16/week @ 2024-02-23 7/week @ 2024-03-01 19/week @ 2024-03-08 45/week @ 2024-03-15 51/week @ 2024-03-22 220/week @ 2024-03-29 18/week @ 2024-04-05 2/week @ 2024-04-12 47/week @ 2024-04-19 8/week @ 2024-04-26

59 downloads per month

MIT license

15KB
251 lines

async-watcher

github crates.io docs.rs

This is a small library that uses notify to implement a file watcher that is debounced. The debouncing helps ensure you don't get too many events on a single file leading to extra work. The original use case of this was to watch a directory and rebuild when there are changes. Without debouncing, a single file could trigger multiple rebuilds. Instead, async-watcher can be used to trigger events after a specific time threshold.

Notify takes care of all of the work, but the debouncing traits weren't async. async-watcher leverages async-trait to provide an async interface for creating watchers.

See the examples for usage.

cli

Included is a command line application that can be used to execute a command when notified of changes. The files to watch are specified with a glob pattern as the first argument. Subsequent arguments are the command to run and its arguments. The program is exposed as a nix flake package called awatch.

example usage:

awatch './{crates,Cargo.toml,Cargo.lock}' echo "crates modified"

Dependencies

~4–13MB
~143K SLoC