Go to file
Max Claus Nunes 2847f41c96 Add more tests 2018-06-20 22:40:09 -03:00
testdata Add more tests 2018-06-20 22:40:09 -03:00
.editorconfig Initial commit 2018-06-17 19:53:26 -03:00
.gitignore Initial commit 2018-06-17 19:53:26 -03:00
.travis.yml Initial commit 2018-06-17 19:53:26 -03:00
CONTRIBUTING.md Initial commit 2018-06-17 19:53:26 -03:00
Gopkg.lock Add few tests for builder and runner parts 2018-06-20 11:54:10 -03:00
Gopkg.toml Add few tests for builder and runner parts 2018-06-20 11:54:10 -03:00
LICENSE Initial commit 2018-06-17 19:53:26 -03:00
Makefile Initial commit 2018-06-17 19:53:26 -03:00
README.md Add more tests 2018-06-20 22:40:09 -03:00
builder.go Add more tests 2018-06-20 22:40:09 -03:00
builder_test.go Add more tests 2018-06-20 22:40:09 -03:00
loggger.go Add support for glob searches on watch and ignore options 2018-06-18 23:47:20 -03:00
main.go Add more tests 2018-06-20 22:40:09 -03:00
main_test.go Initial commit 2018-06-17 19:53:26 -03:00
runner.go Add more tests 2018-06-20 22:40:09 -03:00
runner_test.go Add more tests 2018-06-20 22:40:09 -03:00
watcher.go Add more tests 2018-06-20 22:40:09 -03:00
watcher_test.go Add more tests 2018-06-20 22:40:09 -03:00

README.md

gaper

Software License Build Status Coverage Status Go Doc Go Report Card

Restarts programs when they crash or a watched file changes.

NOT STABLE YET, STILL IN DEVELOPMENT: Please, check out this ticket to follow its progress.

Installation

go get -u github.com/maxcnunes/gaper

Changelog

See Releases for detailed history changes.

Usage

NAME:
   gaper - Used to restart programs when they crash or a watched file changes

USAGE:
   gaper [global options] command [command options] [arguments...]

VERSION:
   0.0.0

COMMANDS:
     help, h  Shows a list of commands or help for one command

GLOBAL OPTIONS:
   --bin-name value                   name for the binary built by Gaper for the executed program
   --build-path value                 path to the program source code
   --build-args value                 build arguments passed to the program
   --verbose                          turns on the verbose messages from Gaper
   --watch value, -w value            list of folders or files to watch for changes
   --ignore value, -i value           list of folders or files to ignore for changes
   --poll-interval value, -p value    how often in milliseconds to poll watched files for changes (default: 500)
   --extensions value, -e value       a comma-delimited list of file extensions to watch for changes (default: "go")
   --no-restart-on value, -n value    don't automatically restart the executed program if it ends:
                                        if "error", an exit code of 0 will still restart.
                                        if "exit", no restart regardless of exit code.
                                        if "success", no restart only if exit code is 0.
   --help, -h                         show help
   --version, -v                      print the version

Examples

Ignore watch over all test files:

--ignore './**/*_test.go'

Contributing

See the Contributing guide for steps on how to contribute to this project.

Reference

This package was heavily inspired by gin and node-supervisor.

Basically, Gaper is a mixing of those projects above. It started from gin code base and I rewrote it aiming to get something similar to node-supervisor (but simpler). A big thanks for those projects and for the people behind it! 👏👏

How is Gaper different of Gin

The main difference is that Gaper removes a layer of complexity from Gin which has a proxy running on top of the executed server. It allows to postpone a build and reload the server when the first call hits it. With Gaper we don't care about that feature, it just restarts your server whenever a change is made.