An open API service indexing awesome lists of open source software.

https://github.com/vojtechvitek/rerun

Re-run command on file system changes
https://github.com/vojtechvitek/rerun

change command file filewatcher fsnotify inotify run

Last synced: 7 months ago
JSON representation

Re-run command on file system changes

Awesome Lists containing this project

README

          

rerun: Re-run command on file system changes
======

Lightweight file-watcher that re-runs given command on FS changes. It has simple CLI and optional config file. By default, it uses 200ms delay, which gives enough time for tools like git to update all directories/files within repository before killing the old process (when you switch branches etc).

#### In development. Only CLI MVP works right now.

# Usage
### `rerun [-watch DIR...] [-ignore DIR...] -run COMMAND [ARG...]`

#### Examples:
```bash
$ rerun -watch ./ -ignore vendor bin -run go run ./cmd/rerun/main.go
```
```bash
$ rerun -watch ./ -ignore vendor bin -run sh -c 'go build -i -o ./bin/rerun ./cmd/rerun/main.go && ./bin/rerun'
```
```bash
$ cd tests && rerun -watch '*_test.go' ../pkg -ignore vendor bin -run go test -run=Test
```

# Installation

```bash
go get -u github.com/VojtechVitek/rerun/cmd/rerun
```
*You might need to [download Go](https://golang.org/dl/) first.*

*TODO: Release page.*

# TODO

- [ ] Regexp matches
- [ ] Verbose mode
- [ ] Interactive mode
- [ ] Config file, as an alternative to direct CLI invocation
- [ ] Act when a new dir is added/removed
- [ ] Support Windows - https://stackoverflow.com/a/47059064/385548 https://stackoverflow.com/questions/22470193/why-wont-go-kill-a-child-process-correctly

```yaml
api:
watch:
- cmd
- *.go
ignore:
- bin
- *_test.go
cmd:
- go run cmd/api/main.go -flags args

test-login:
name: Test login
watch:
- tests/e2e
- services/auth
- data
run:
- go test -run=Login
```

Written in [golang](https://github.com/golang/go).

Uses [fsnotify](https://github.com/fsnotify/fsnotify) behind the scenes, so technically it should work on most platforms including Linux, Mac OS and Windows.

# License

Licensed under the [MIT License](./LICENSE).