2017-09-10 22:07:28 +02:00
|
|
|
---
|
2017-10-01 18:57:52 +02:00
|
|
|
title: Archive
|
2018-04-25 07:20:12 +02:00
|
|
|
series: customization
|
|
|
|
hideFromIndex: true
|
|
|
|
weight: 40
|
2017-09-10 22:07:28 +02:00
|
|
|
---
|
|
|
|
|
2017-10-01 18:57:52 +02:00
|
|
|
The binaries built will be archived together with the `README` and `LICENSE` files into a
|
2017-09-10 22:07:28 +02:00
|
|
|
`tar.gz` file. In the `archive` section you can customize the archive name,
|
2017-10-01 18:57:52 +02:00
|
|
|
additional files, and format.
|
2017-09-10 22:07:28 +02:00
|
|
|
|
2017-10-01 18:57:52 +02:00
|
|
|
Here is a commented `archive` section with all fields specified:
|
2017-09-10 22:07:28 +02:00
|
|
|
|
|
|
|
```yml
|
|
|
|
# .goreleaser.yml
|
|
|
|
archive:
|
2018-07-09 08:57:46 +02:00
|
|
|
# Archive name template.
|
2017-12-27 01:19:58 +02:00
|
|
|
# Defaults:
|
|
|
|
# - if format is `tar.gz` or `zip`:
|
|
|
|
# - `{{ .ProjectName }}_{{ .Version }}_{{ .Os }}_{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}`
|
|
|
|
# - if format is `binary`:
|
|
|
|
# - `{{ .Binary }}_{{ .Version }}_{{ .Os }}_{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}`
|
2017-09-10 22:07:28 +02:00
|
|
|
name_template: "{{ .ProjectName }}_{{ .Version }}_{{ .Os }}_{{ .Arch }}"
|
|
|
|
|
2017-12-27 01:19:58 +02:00
|
|
|
# Replacements for GOOS and GOARCH in the archive name.
|
|
|
|
# Keys should be valid GOOSs or GOARCHs.
|
|
|
|
# Values are the respective replacements.
|
|
|
|
# Default is empty.
|
|
|
|
replacements:
|
|
|
|
amd64: 64-bit
|
|
|
|
386: 32-bit
|
|
|
|
darwin: macOS
|
|
|
|
linux: Tux
|
|
|
|
|
2017-10-02 18:43:03 +02:00
|
|
|
# Set to true, if you want all files in the archive to be in a single directory.
|
|
|
|
# If set to true and you extract the archive 'goreleaser_Linux_arm64.tar.gz',
|
|
|
|
# you get a folder 'goreleaser_Linux_arm64'.
|
|
|
|
# If set to false, all files are extracted separately.
|
2018-11-13 17:49:26 +02:00
|
|
|
# You can also set it to a custom folder name (templating is supported).
|
2017-10-02 18:43:03 +02:00
|
|
|
# Default is false.
|
|
|
|
wrap_in_directory: true
|
|
|
|
|
2017-09-10 22:07:28 +02:00
|
|
|
# Archive format. Valid options are `tar.gz`, `zip` and `binary`.
|
2017-10-01 18:57:52 +02:00
|
|
|
# If format is `binary`, no archives are created and the binaries are instead uploaded directly.
|
|
|
|
# In that case name_template and the below specified files are ignored.
|
|
|
|
# Default is `tar.gz`.
|
2017-09-10 22:07:28 +02:00
|
|
|
format: zip
|
|
|
|
|
2017-10-01 18:57:52 +02:00
|
|
|
# Can be used to change the archive formats for specific GOOSs.
|
2017-09-10 22:07:28 +02:00
|
|
|
# Most common use case is to archive as zip on Windows.
|
2017-10-01 18:57:52 +02:00
|
|
|
# Default is empty.
|
2017-09-10 22:07:28 +02:00
|
|
|
format_overrides:
|
|
|
|
- goos: windows
|
|
|
|
format: zip
|
|
|
|
|
|
|
|
# Additional files/globs you want to add to the archive.
|
|
|
|
# Defaults are any files matching `LICENCE*`, `LICENSE*`,
|
2017-10-01 18:57:52 +02:00
|
|
|
# `README*` and `CHANGELOG*` (case-insensitive).
|
2017-09-10 22:07:28 +02:00
|
|
|
files:
|
|
|
|
- LICENSE.txt
|
|
|
|
- README.md
|
|
|
|
- CHANGELOG.md
|
|
|
|
- docs/*
|
|
|
|
- design/*.png
|
2018-07-21 15:21:13 +02:00
|
|
|
- templates/**/*
|
2017-09-10 22:07:28 +02:00
|
|
|
```
|
2017-12-08 00:21:36 +02:00
|
|
|
|
2018-07-09 08:57:46 +02:00
|
|
|
> Learn more about the [name template engine](/templates).
|
2018-03-12 02:07:03 +02:00
|
|
|
|
2018-07-21 15:21:13 +02:00
|
|
|
You can add entire folders, its subfolders and files by using the glob notation,
|
|
|
|
for example: `myfolder/**/*`.
|
2018-07-20 01:32:28 +02:00
|
|
|
|
2018-03-12 02:07:03 +02:00
|
|
|
## Packaging only the binaries
|
|
|
|
|
|
|
|
Since GoReleaser will always add the `README` and `LICENSE` files to the
|
|
|
|
archive if the file list is empty, you'll need to provide a filled `files`
|
|
|
|
on the archive section.
|
|
|
|
|
|
|
|
A working hack is to use something like this:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
# goreleaser.yml
|
|
|
|
archive:
|
|
|
|
files:
|
|
|
|
- none*
|
|
|
|
```
|
|
|
|
|
|
|
|
This would add all files matching the glob `none*`, provide that you don't
|
|
|
|
have any files matching that glob, only the binary will be added to the
|
|
|
|
archive.
|
|
|
|
|
|
|
|
For more information, check [#602](https://github.com/goreleaser/goreleaser/issues/602)
|