watchexec/lib
Félix Saparelli 23d794ed7e
Apply tabs project-wide
2021-08-24 20:22:25 +12:00
..
examples Add InitConfig::builder() to be a little more idiomatic 2021-08-24 19:59:11 +12:00
src Take IntoIterator<AsRef<str>> to be more flexible on input 2021-08-24 20:14:01 +12:00
tests Add InitConfig::builder() to be a little more idiomatic 2021-08-24 19:59:11 +12:00
CITATION.cff Add citation.cff 2021-07-29 00:45:13 +12:00
Cargo.toml Update to miette 1.0 beta 2021-08-23 02:37:13 +12:00
README.md Link to website for downloads 2021-07-10 03:48:12 +12:00

README.md

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)
    }
}