2018-06-21 20:36:07 -05:00
< p align = "center" >
< img width = "200px" src = "https://raw.githubusercontent.com/maxcnunes/gaper/master/gopher-gaper.png" >
< h3 align = "center" > gaper< / h3 >
< p align = "center" >
2018-06-22 07:01:36 -05:00
Used to build and restart a Go project when it crashes or some watched file changes
< br / >
2018-06-21 20:36:07 -05:00
< b > Aimed to be used in development only.< / b >
< / p >
< / p >
---
2018-06-16 19:22:21 -05:00
[![Software License ](https://img.shields.io/badge/license-MIT-brightgreen.svg?style=flat-square )](LICENSE.md)
2018-06-20 21:15:58 -05:00
[![Linux - Build Status ](https://travis-ci.org/maxcnunes/gaper.svg?branch=master )](https://travis-ci.org/maxcnunes/gaper)
[![Windows - Build status ](https://ci.appveyor.com/api/projects/status/e0g00kmxwv44?svg=true )](https://ci.appveyor.com/project/maxcnunes/gaper)
2018-06-16 19:22:21 -05:00
[![Coverage Status ](https://codecov.io/gh/maxcnunes/gaper/branch/master/graph/badge.svg )](https://codecov.io/gh/maxcnunes/gaper)
[![Go Doc ](https://img.shields.io/badge/godoc-reference-blue.svg?style=flat-square )](http://godoc.org/github.com/maxcnunes/gaper)
[![Go Report Card ](https://goreportcard.com/badge/github.com/maxcnunes/gaper )](https://goreportcard.com/report/github.com/maxcnunes/gaper)
2018-06-20 22:48:36 -05:00
[![Powered By: GoReleaser ](https://img.shields.io/badge/powered%20by-goreleaser-green.svg?style=flat-square )](https://github.com/goreleaser)
2018-06-16 19:22:21 -05:00
## Installation
```
2018-06-22 07:01:36 -05:00
go get -u github.com/maxcnunes/gaper/cmd/gaper
2018-06-16 19:22:21 -05:00
```
## Changelog
See [Releases ](https://github.com/maxcnunes/gaper/releases ) for detailed history changes.
## Usage
```
NAME:
2018-06-22 07:01:36 -05:00
gaper - Used to build and restart a Go project when it crashes or some watched file changes
2018-06-16 19:22:21 -05:00
USAGE:
gaper [global options] command [command options] [arguments...]
VERSION:
2018-06-22 07:01:36 -05:00
version
2018-06-16 19:22:21 -05:00
COMMANDS:
help, h Shows a list of commands or help for one command
GLOBAL OPTIONS:
2018-06-22 07:01:36 -05:00
--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
2018-07-22 08:30:30 -05:00
--disable-default-ignore turns off default ignore for hidden files and folders, "*_test.go" files, and vendor folder
2018-06-22 07:01:36 -05:00
--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 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
2018-06-16 19:22:21 -05:00
```
2019-01-19 13:39:53 -06:00
### Watch and Ignore paths
For those options gaper supports static paths (e.g. `build/` , `seed.go` ) or glob paths (e.g. `migrations/**/up.go` , `*_test.go` ).
On using a path to a directory please add a `/` at the end (e.g. `build/` ) to make sure gaper won't include other matches that starts with that same value (e.g. `build/` , `build_settings.go` ).
### Default ignore settings
2018-07-22 08:30:30 -05:00
Since in most projects there is no need to watch changes of:
* hidden files and folders
* test files (`*_test.go`)
* vendor folder
Gaper by default ignores those cases already. Although, if you need Gaper to watch those files anyway it is possible to disable this setting with `--disable-default-ignore` argument.
2018-06-20 20:40:09 -05:00
### Examples
2018-07-22 08:30:30 -05:00
Using all defaults provided by Gaper:
```
gaper
```
2018-06-20 20:40:09 -05:00
Ignore watch over all test files:
2018-07-22 08:41:26 -05:00
> no need for this in case if you are not using `--disable-default-ignore`
2018-07-22 08:30:30 -05:00
2018-06-20 20:40:09 -05:00
```
--ignore './**/*_test.go'
```
2018-06-16 19:22:21 -05:00
## Contributing
See the [Contributing guide ](/CONTRIBUTING.md ) for steps on how to contribute to this project.
## Reference
This package was heavily inspired by [gin ](https://github.com/codegangsta/gin ) and [node-supervisor ](https://github.com/petruisfan/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!
:clap::clap:
### 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.