funzzy Crate version CI integration tests CI Checks

Yet another fancy watcher. (Inspired by antr / entr)

Configure execution of different commands using semantic YAML. See also funzzy.nvim

```yaml

.watch.yaml

list here all the events and the commands that it should execute

TIP: include '.watch.yaml' in your .git/info/exclude to ignore it.

Command templates for custom scripts

Motivation

Create a lightweight watcher to run my tests every time something in my project change. So I won't forget to keep my tests passing. Funzzy was made with Rust that is why it consumes almost nothing to run.

Installing

bash brew tap cristianoliveira/tap brew update brew install funzzy

bash curl -s https://raw.githubusercontent.com/cristianoliveira/funzzy/master/linux-install.sh | sh

bash cargo install funzzy

*Make sure you have $HOME/.cargo/bin in your PATH export $PATH:$HOME/.cargo/bin

From source

Make sure you have installed the follow dependencies:

Clone this repo and do:

bash make install

Running

Initializing with boilerplate:

bash funzzy init

Change the YAML as you want. Then run:

bash funzzy

Filtering task by target:

bash funzzy --target="my task"

Run with some arbitrary command and stdin

bash find . -R '**.rs' | funzzy 'cargo build'

Templates for composing commands

bash find . -R '**.rs' | funzzy 'cargo lint {{filepath}}'

See more on examples or in the integration specs

Automated tests

Running unit tests:

bash cargo test

or simple make tests

Running integration tests:

make integration

Code Style

We use clippy for lintting the funzzy's source code. Make sure you had validated it before commit.

Contributing

Pull Requests are really welcome! Others support also.

Pull Request should have unit tests

License

This project was made under MIT License.