watchexec/lib
2021-08-22 18:56:57 +12:00
..
examples Add print_out example 2021-08-22 02:53:31 +12:00
src Allow an outcome to be determined by the action handler without &mut! 2021-08-22 18:56:57 +12:00
tests Add docs for error_handler as it's a bit tricky 2021-08-21 22:30:19 +12:00
.rustfmt.toml Start on watchexec v2 2021-08-16 21:49:12 +12:00
Cargo.toml Allow an outcome to be determined by the action handler without &mut! 2021-08-22 18:56:57 +12:00
CITATION.cff Add citation.cff 2021-07-29 00:45:13 +12:00
README.md Link to website for downloads 2021-07-10 03:48:12 +12:00

Crates.io page API Docs Crate license: Apache 2.0 MSRV: 1.43.0 (breaking) CI status

Watchexec library

The library which powers Watchexec CLI and other tools.

Quick start

use watchexec::{
    config::ConfigBuilder,
    error::Result,
    pathop::PathOp,
    run::{
        ExecHandler,
        Handler,
        watch,
    },
};

fn main() -> Result<()> {
    let config = ConfigBuilder::default()
        .clear_screen(true)
        .run_initially(true)
        .paths(vec![ "/path/to/dir".into() ])
        .cmd(vec![ "date; seq 1 10".into() ])
        .build()?;

    let handler = MyHandler(ExecHandler::new(options)?);
    watch(&handler)
}

struct MyHandler(ExecHandler);

impl Handler for MyHandler {
    fn args(&self) -> Config {
        self.0.args()
    }

    fn on_manual(&self) -> Result<bool> {
        println!("Running manually!");
        self.0.on_manual()
    }

    fn on_update(&self, ops: &[PathOp]) -> Result<bool> {
        println!("Running manually {:?}", ops);
        self.0.on_update(ops)
    }
}