2018-03-28 15:31:09 +02:00
|
|
|
---
|
|
|
|
title: Global Hooks
|
2018-04-24 22:20:12 -07:00
|
|
|
series: customization
|
|
|
|
hideFromIndex: true
|
|
|
|
weight: 20
|
2018-03-28 15:31:09 +02:00
|
|
|
---
|
|
|
|
|
|
|
|
Some builds may need pre-build steps before building, e.g. `go generate`.
|
|
|
|
The `before` section allows for global hooks which will be executed before
|
|
|
|
the build is started.
|
|
|
|
|
|
|
|
The configuration is very simple, here is a complete example:
|
|
|
|
|
|
|
|
```yml
|
|
|
|
# .goreleaser.yml
|
|
|
|
before:
|
2019-03-03 14:12:22 -03:00
|
|
|
# Templates for the commands to be ran.
|
2018-03-28 15:31:09 +02:00
|
|
|
hooks:
|
|
|
|
- make clean
|
|
|
|
- go generate ./...
|
2019-08-27 14:12:19 -03:00
|
|
|
- go mod tidy
|
2019-03-03 14:12:22 -03:00
|
|
|
- touch {{ .Env.FILE_TO_TOUCH }}
|
2018-03-28 15:31:09 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
If any of the hooks fails the build process is aborted.
|
2018-08-15 00:18:59 -03:00
|
|
|
|
|
|
|
It is important to note that you can't have "complex" commands, like
|
|
|
|
`bash -c "echo foo bar"` or `foo | bar` or anything like that. If you need
|
|
|
|
to do things that are more complex than just calling a command with some
|
|
|
|
attributes, wrap it in a shell script or into your `Makefile`.
|
2019-03-03 14:12:22 -03:00
|
|
|
|
|
|
|
> Learn more about the [name template engine](/templates).
|