1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-01-26 04:22:05 +02:00

114 lines
2.6 KiB
Markdown
Raw Normal View History

2017-09-10 17:07:28 -03:00
---
title: Builds
series: customization
hideFromIndex: true
weight: 30
2017-09-10 17:07:28 -03:00
---
2018-09-05 10:38:33 -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
the name of the binary, flags, environment variables, hooks and etc.
2017-09-10 17:07:28 -03:00
Here is a commented `builds` section with all fields specified:
2017-09-10 17:07:28 -03:00
```yml
# .goreleaser.yml
builds:
# You can have multiple builds defined as a yaml list
2017-09-10 17:07:28 -03:00
-
# Path to main.go file or main package.
# Default is `.`.
2017-09-10 17:07:28 -03:00
main: ./cmd/main.go
2018-07-08 23:57:46 -07:00
# Name template for the binary final name.
2017-09-10 17:07:28 -03:00
# Default is the name of the project directory.
binary: program
# Set flags for custom build tags.
# Default is empty.
flags:
- -tags
- dev
2017-09-10 17:07:28 -03:00
# Custom asmflags templates.
# Default is empty.
asmflags:
- -D mysymbol
- all=-trimpath={{.Env.GOPATH}}
# Custom gcflags templates.
# Default is empty.
gcflags:
- all=-trimpath={{.Env.GOPATH}}
- ./dontoptimizeme=-N
# Custom ldflags templates.
# Default is `-s -w -X main.version={{.Version}} -X main.commit={{.Commit}} -X main.date={{.Date}}`.
ldflags:
- -s -w -X main.build={{.Version}}
- ./usemsan=-msan
2017-09-10 17:07:28 -03: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
# 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
# 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
# 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
# List of combinations of GOOS + GOARCH + GOARM to ignore.
# Default is empty.
ignore:
- goos: darwin
goarch: 386
- goos: linux
goarch: arm
goarm: 7
# Hooks can be used to customize the final binary,
# for example, to run generators.
2017-09-10 17:07:28 -03:00
# Default is both hooks empty.
hooks:
pre: rice embed-go
post: ./script.sh
```
2018-07-08 23:57:46 -07:00
> Learn more about the [name template engine](/templates).
## Passing environment variables to ldflags
You can do that by using `{{ .Env.VARIABLE_NAME }}` in the template, for
example:
```yaml
builds:
- ldflags:
- -s -w -X "main.goversion={{.Env.GOVERSION}}"
```
Then you can run:
```console
GOVERSION=$(go version) goreleaser
```