Executes commands in response to file modifications
Find a file
dependabot[bot] f538b74e81
Bump actions/upload-artifact from 3 to 4 (#733)
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2024-04-20 16:42:08 +12:00
.cargo Learn some build optimisations from binstall (#416) 2022-09-07 06:00:08 +00:00
.github Bump actions/upload-artifact from 3 to 4 (#733) 2024-04-20 16:42:08 +12:00
bin Fix queueing behaviour (#734) 2023-12-19 11:22:59 +00:00
completions Canonicalise paths for ignore discovery (#760) 2024-01-04 09:32:47 +00:00
crates feat(cli): Add NO_COLOR support (#779) 2024-02-11 05:13:41 +00:00
doc feat(cli): Add NO_COLOR support (#779) 2024-02-11 05:13:41 +00:00
.clippy-lints feat(cli): Add NO_COLOR support (#779) 2024-02-11 05:13:41 +00:00
.editorconfig Fix cli tests 2021-08-24 22:53:44 +12:00
.gitattributes Fix and adjust docs (#530) 2023-03-18 10:23:46 +00:00
.gitignore Clap 4 and revamp manpage, completions (#513) 2023-03-05 14:57:34 +13:00
.rustfmt.toml Apply tabs project-wide 2021-08-24 20:22:25 +12:00
Cargo.lock Bump mio from 0.8.10 to 0.8.11 (#796) 2024-03-06 13:01:52 +13:00
Cargo.toml Optimise ignore file gathering (#663) 2024-01-01 05:01:14 +00:00
CITATION.cff release: watchexec-cli v1.25.1 (#764) 2024-01-05 04:41:32 +00:00
CONTRIBUTING.md Remove obsolete release order (#683) 2023-11-26 03:15:29 +00:00
LICENSE Create LICENSE 2016-09-18 16:43:26 -04:00
README.md New option: --signal-map (#710) 2023-12-09 09:30:58 +00:00

CI status on main branch

Watchexec

Software development often involves running the same commands over and over. Boring!

watchexec is a simple, standalone tool that watches a path and runs a command whenever it detects modifications.

Example use cases:

  • Automatically run unit tests
  • Run linters/syntax checkers
  • Rebuild artifacts

Features

  • Simple invocation and use, does not require a cryptic command line involving xargs
  • Runs on OS X, Linux, and Windows
  • Monitors current directory and all subdirectories for changes
  • Coalesces multiple filesystem events into one, for editors that use swap/backup files during saving
  • Loads .gitignore and .ignore files
  • Uses process groups to keep hold of forking programs
  • Provides the paths that changed in environment variables or STDIN
  • Does not require a language runtime, not tied to any particular language or ecosystem
  • And more!

Quick start

Watch all JavaScript, CSS and HTML files in the current directory and all subdirectories for changes, running npm run build when a change is detected:

$ watchexec -e js,css,html npm run build

Call/restart python server.py when any Python file in the current directory (and all subdirectories) changes:

$ watchexec -r -e py -- python server.py

More usage examples: in the CLI README!

Install

Packaging status

All options in detail: in the CLI README, in the online help (watchexec -h, watchexec --help, or watchexec --manual), and in the manual page.

Augment

Watchexec pairs well with:

  • checkexec: to run only when source files are newer than a target file
  • just: a modern alternative to make
  • systemfd: socket-passing in development

Extend

Downstreams

Selected downstreams of watchexec and associated crates: