2017-09-10 17:07:28 -03:00
|
|
|
---
|
2017-10-01 18:57:52 +02:00
|
|
|
title: Builds
|
2017-09-10 17:07:28 -03:00
|
|
|
---
|
|
|
|
|
2018-09-20 17:44:25 -03:00
|
|
|
Builds can be customized in multiple ways.
|
|
|
|
You can specify for which `GOOS`, `GOARCH` and `GOARM` binaries are built
|
|
|
|
(goreleaser will generate a matrix of all combinations), and you can changed
|
2018-09-05 10:38:33 -03:00
|
|
|
the name of the binary, flags, environment variables, hooks and etc.
|
2017-09-10 17:07:28 -03:00
|
|
|
|
2017-10-01 18:57:52 +02:00
|
|
|
Here is a commented `builds` section with all fields specified:
|
2017-09-10 17:07:28 -03:00
|
|
|
|
|
|
|
```yml
|
|
|
|
# .goreleaser.yml
|
|
|
|
builds:
|
2017-10-01 18:57:52 +02:00
|
|
|
# You can have multiple builds defined as a yaml list
|
2017-09-10 17:07:28 -03:00
|
|
|
-
|
2019-04-14 15:16:01 -03:00
|
|
|
# ID of the build.
|
2019-06-28 09:09:19 -03:00
|
|
|
# Defaults to the project name.
|
2019-04-14 15:16:01 -03:00
|
|
|
id: "my-build"
|
|
|
|
|
2020-01-13 18:23:00 +01:00
|
|
|
# Path to project's (sub)directory containing Go code.
|
|
|
|
# This is the working directory for the Go build command(s).
|
|
|
|
# Default is `.`.
|
|
|
|
dir: go
|
|
|
|
|
2017-09-10 17:07:28 -03:00
|
|
|
# Path to main.go file or main package.
|
2017-10-01 18:57:52 +02:00
|
|
|
# Default is `.`.
|
2017-09-10 17:07:28 -03:00
|
|
|
main: ./cmd/main.go
|
|
|
|
|
2019-02-04 09:42:13 -02:00
|
|
|
# Binary name.
|
2019-04-09 14:14:28 +02:00
|
|
|
# Can be a path (e.g. `bin/app`) to wrap the binary in a directory.
|
2017-09-10 17:07:28 -03:00
|
|
|
# Default is the name of the project directory.
|
|
|
|
binary: program
|
|
|
|
|
2019-01-17 10:50:00 -02:00
|
|
|
# Custom flags templates.
|
2017-10-01 18:57:52 +02:00
|
|
|
# Default is empty.
|
2018-05-14 17:22:55 -07:00
|
|
|
flags:
|
2018-09-20 17:44:25 -03:00
|
|
|
- -tags=dev
|
2019-01-17 10:50:00 -02:00
|
|
|
- -v
|
2017-09-10 17:07:28 -03:00
|
|
|
|
2018-05-14 17:22:55 -07:00
|
|
|
# Custom asmflags templates.
|
2018-04-20 04:26:04 -07:00
|
|
|
# Default is empty.
|
2018-05-14 17:22:55 -07:00
|
|
|
asmflags:
|
|
|
|
- -D mysymbol
|
|
|
|
- all=-trimpath={{.Env.GOPATH}}
|
2018-04-20 04:26:04 -07:00
|
|
|
|
2018-05-14 17:22:55 -07:00
|
|
|
# Custom gcflags templates.
|
2018-04-20 04:26:04 -07:00
|
|
|
# Default is empty.
|
2018-05-14 17:22:55 -07:00
|
|
|
gcflags:
|
|
|
|
- all=-trimpath={{.Env.GOPATH}}
|
|
|
|
- ./dontoptimizeme=-N
|
2018-04-20 04:26:04 -07:00
|
|
|
|
2018-05-14 17:22:55 -07:00
|
|
|
# Custom ldflags templates.
|
2019-11-27 16:38:22 -08:00
|
|
|
# Default is `-s -w -X main.version={{.Version}} -X main.commit={{.Commit}} -X main.date={{.Date}} -X main.builtBy=goreleaser`.
|
2018-05-14 17:22:55 -07:00
|
|
|
ldflags:
|
|
|
|
- -s -w -X main.build={{.Version}}
|
|
|
|
- ./usemsan=-msan
|
2017-09-10 17:07:28 -03:00
|
|
|
|
2017-10-01 18:57:52 +02:00
|
|
|
# Custom environment variables to be set during the builds.
|
|
|
|
# Default is empty.
|
2017-09-10 17:07:28 -03:00
|
|
|
env:
|
|
|
|
- CGO_ENABLED=0
|
|
|
|
|
2017-10-01 18:57:52 +02:00
|
|
|
# GOOS list to build for.
|
|
|
|
# For more info refer to: https://golang.org/doc/install/source#environment
|
|
|
|
# Defaults are darwin and linux.
|
2017-09-10 17:07:28 -03:00
|
|
|
goos:
|
|
|
|
- freebsd
|
|
|
|
- windows
|
|
|
|
|
2017-10-01 18:57:52 +02:00
|
|
|
# GOARCH to build for.
|
|
|
|
# For more info refer to: https://golang.org/doc/install/source#environment
|
|
|
|
# Defaults are 386 and amd64.
|
2017-09-10 17:07:28 -03:00
|
|
|
goarch:
|
|
|
|
- amd64
|
|
|
|
- arm
|
|
|
|
- arm64
|
|
|
|
|
2017-10-01 18:57:52 +02:00
|
|
|
# GOARM to build for when GOARCH is arm.
|
|
|
|
# For more info refer to: https://golang.org/doc/install/source#environment
|
|
|
|
# Default is only 6.
|
2017-09-10 17:07:28 -03:00
|
|
|
goarm:
|
|
|
|
- 6
|
|
|
|
- 7
|
|
|
|
|
2020-01-26 14:36:00 -03:00
|
|
|
# GOMIPS and GOMIPS64 to build when GOARCH is mips, mips64, mipsle or mips64le.
|
|
|
|
# For more info refer to: https://golang.org/doc/install/source#environment
|
|
|
|
# Default is empty.
|
|
|
|
gomips:
|
|
|
|
- hardfloat
|
|
|
|
- softfloat
|
|
|
|
|
2017-09-10 17:07:28 -03:00
|
|
|
# List of combinations of GOOS + GOARCH + GOARM to ignore.
|
|
|
|
# Default is empty.
|
|
|
|
ignore:
|
|
|
|
- goos: darwin
|
|
|
|
goarch: 386
|
|
|
|
- goos: linux
|
|
|
|
goarch: arm
|
|
|
|
goarm: 7
|
2020-01-26 14:36:00 -03:00
|
|
|
- goarm: mips64
|
|
|
|
gomips: hardfloat
|
2017-09-10 17:07:28 -03:00
|
|
|
|
2017-10-01 18:57:52 +02:00
|
|
|
# Hooks can be used to customize the final binary,
|
|
|
|
# for example, to run generators.
|
2019-04-14 15:16:20 -03:00
|
|
|
# Those fields allow templates.
|
2017-09-10 17:07:28 -03:00
|
|
|
# Default is both hooks empty.
|
|
|
|
hooks:
|
|
|
|
pre: rice embed-go
|
2020-04-12 16:13:20 +01:00
|
|
|
post: ./script.sh {{ .Path }}
|
2020-04-02 15:18:05 +02:00
|
|
|
|
|
|
|
# If true, skip the build.
|
|
|
|
# Useful for library projects.
|
|
|
|
# Default is false
|
|
|
|
skip: false
|
2017-09-10 17:07:28 -03:00
|
|
|
```
|
2017-12-03 16:19:57 -02:00
|
|
|
|
2018-07-08 23:57:46 -07:00
|
|
|
> Learn more about the [name template engine](/templates).
|
|
|
|
|
2017-12-03 16:19:57 -02:00
|
|
|
## Passing environment variables to ldflags
|
|
|
|
|
|
|
|
You can do that by using `{{ .Env.VARIABLE_NAME }}` in the template, for
|
|
|
|
example:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
builds:
|
2018-05-14 17:22:55 -07:00
|
|
|
- ldflags:
|
|
|
|
- -s -w -X "main.goversion={{.Env.GOVERSION}}"
|
2017-12-03 16:19:57 -02:00
|
|
|
```
|
|
|
|
|
|
|
|
Then you can run:
|
|
|
|
|
2019-03-24 20:10:30 -03:00
|
|
|
```sh
|
2017-12-03 16:19:57 -02:00
|
|
|
GOVERSION=$(go version) goreleaser
|
|
|
|
```
|
2018-10-04 22:23:10 -03:00
|
|
|
|
2020-04-12 16:13:20 +01:00
|
|
|
## Build Hooks
|
|
|
|
|
|
|
|
Both pre and post hooks run **for each build target**, regardless of whether
|
|
|
|
these targets are generated via a matrix of OSes and architectures
|
|
|
|
or defined explicitly.
|
|
|
|
|
|
|
|
In addition to simple declarations as shown above _multiple_ hooks can be declared
|
|
|
|
to help retaining reusability of config between different build environments.
|
|
|
|
|
|
|
|
```yml
|
|
|
|
builds:
|
|
|
|
-
|
|
|
|
id: "with-hooks"
|
|
|
|
targets:
|
|
|
|
- "darwin_amd64"
|
|
|
|
- "windows_amd64"
|
|
|
|
hooks:
|
|
|
|
pre:
|
|
|
|
- first-script.sh
|
|
|
|
- second-script.sh
|
|
|
|
post:
|
|
|
|
- upx "{{ .Path }}"
|
|
|
|
- codesign -project="{{ .ProjectName }}" "{{ .Path }}"
|
|
|
|
```
|
|
|
|
|
|
|
|
Each hook can also have its own work directory and environment variables:
|
|
|
|
|
|
|
|
```yml
|
|
|
|
builds:
|
|
|
|
-
|
|
|
|
id: "with-hooks"
|
|
|
|
targets:
|
|
|
|
- "darwin_amd64"
|
|
|
|
- "windows_amd64"
|
|
|
|
hooks:
|
|
|
|
pre:
|
|
|
|
- cmd: first-script.sh
|
|
|
|
dir: "{{ dir .Dist}}"
|
|
|
|
env:
|
|
|
|
- HOOK_SPECIFIC_VAR={{ .Env.GLOBAL_VAR }}
|
|
|
|
- second-script.sh
|
|
|
|
```
|
|
|
|
|
|
|
|
All properties of a hook (`cmd`, `dir` and `env`) support [templating](/customization/#Name%20Templates)
|
|
|
|
with `post` hooks having binary artifact available (as these run _after_ the build).
|
|
|
|
Additionally the following build details are exposed to both `pre` and `post` hooks:
|
|
|
|
|
|
|
|
| Key | Description |
|
|
|
|
| :-------------: | :------------------------------------: |
|
|
|
|
| .Name | Filename of the binary, e.g. `bin.exe` |
|
|
|
|
| .Ext | Extension, e.g. `.exe` |
|
|
|
|
| .Path | Absolute path to the binary |
|
|
|
|
| .Target | Build target, e.g. `darwin_amd64` |
|
|
|
|
|
|
|
|
Environment variables are inherited and overridden in the following order:
|
|
|
|
|
|
|
|
- global (`env`)
|
|
|
|
- build (`builds[].env`)
|
|
|
|
- hook (`builds[].hooks.pre[].env` and `builds[].hooks.post[].env`)
|
|
|
|
|
2018-10-04 22:23:10 -03:00
|
|
|
## Go Modules
|
|
|
|
|
2019-02-26 17:17:30 -03:00
|
|
|
If you use Go 1.11+ with go modules or vgo, when GoReleaser runs it may
|
2018-10-04 22:23:10 -03:00
|
|
|
try to download the dependencies. Since several builds run in parallel, it is
|
|
|
|
very likely to fail.
|
|
|
|
|
2020-02-17 13:13:28 +01:00
|
|
|
You can solve this by running `go mod download` before calling `goreleaser` or
|
2018-10-04 22:23:10 -03:00
|
|
|
by adding a [hook][] doing that on your `.goreleaser.yaml` file:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
before:
|
|
|
|
hooks:
|
2020-02-17 13:13:28 +01:00
|
|
|
- go mod download
|
2018-10-04 22:23:10 -03:00
|
|
|
# rest of the file...
|
|
|
|
```
|
|
|
|
|
|
|
|
[hook]: /hooks
|
2020-01-31 19:38:56 +01:00
|
|
|
|
|
|
|
## Define Build Tag
|
|
|
|
|
|
|
|
GoReleaser uses `git describe` to get the build tag. You can set
|
|
|
|
a different build tag using the environment variable `GORELEASER_CURRENT_TAG`.
|
2020-05-10 16:57:11 -03:00
|
|
|
This is useful in scenarios where two tags point to the same commit.
|