Go to file
Max Claus Nunes a2c23bc074 Ignore cmd folder 2018-07-22 09:33:50 -03:00
cmd/gaper Improve test coverage 2018-07-12 10:27:07 -03:00
testdata Improve test coverage 2018-07-12 10:27:07 -03:00
.editorconfig Initial commit 2018-06-17 19:53:26 -03:00
.gitignore Improve test coverage 2018-07-12 10:27:07 -03:00
.goreleaser.yml Move cli to a different folder so Godoc works for the rest 2018-06-22 13:45:45 -03:00
.travis.yml Move cli to a different folder so Godoc works for the rest 2018-06-22 13:45:45 -03:00
CONTRIBUTING.md Initial commit 2018-06-17 19:53:26 -03:00
Gopkg.lock Improve test coverage 2018-07-12 10:27:07 -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 Fix codecov coverage percentage 2018-07-12 10:48:17 -03:00
README.md Move cli to a different folder so Godoc works for the rest 2018-06-22 13:45:45 -03:00
appveyor.yml Fix appveyor setting 2018-06-22 22:14:56 -03:00
builder.go Move cli to a different folder so Godoc works for the rest 2018-06-22 13:45:45 -03:00
builder_test.go Move cli to a different folder so Godoc works for the rest 2018-06-22 13:45:45 -03:00
codecov.yml Ignore cmd folder 2018-07-22 09:33:50 -03:00
gaper.go Apply improvements suggested by the linter 2018-07-12 10:35:44 -03:00
gaper_test.go Improve test coverage 2018-07-12 10:27:07 -03:00
gopher-gaper.png Add logo 2018-06-21 22:22:05 -03:00
loggger.go Move cli to a different folder so Godoc works for the rest 2018-06-22 13:45:45 -03:00
runner.go Improve test coverage 2018-07-12 10:27:07 -03:00
runner_test.go Improve test coverage 2018-07-12 10:27:07 -03:00
watcher.go Apply improvements suggested by the linter 2018-07-12 10:35:44 -03:00
watcher_test.go Improve test coverage 2018-07-12 10:27:07 -03:00

README.md

gaper

Used to build and restart a Go project when it crashes or some watched file changes
Aimed to be used in development only.


Software License Linux - Build Status Windows - Build status Coverage Status Go Doc Go Report Card Powered By: GoReleaser

Installation

go get -u github.com/maxcnunes/gaper/cmd/gaper

Changelog

See Releases for detailed history changes.

Usage

NAME:
   gaper - Used to build and restart a Go project when it crashes or some watched file changes

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

VERSION:
   version

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 (default current directory name)
   --build-path value               path to the program source code (default: ".")
   --build-args value               arguments used on building the program
   --program-args value             arguments used on executing 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
                                      (always ignores all hidden files and directories)
   --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 supervised 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.