1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-01-24 04:16:27 +02:00
goreleaser/www/content/archive.md

93 lines
2.8 KiB
Markdown
Raw Normal View History

2017-09-10 17:07:28 -03:00
---
title: Archive
series: customization
hideFromIndex: true
weight: 40
2017-09-10 17:07:28 -03:00
---
The binaries built will be archived together with the `README` and `LICENSE` files into a
2017-09-10 17:07:28 -03:00
`tar.gz` file. In the `archive` section you can customize the archive name,
additional files, and format.
2017-09-10 17:07:28 -03:00
Here is a commented `archive` section with all fields specified:
2017-09-10 17:07:28 -03:00
```yml
# .goreleaser.yml
archive:
2018-07-08 23:57:46 -07:00
# Archive name template.
# 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 17:07:28 -03:00
name_template: "{{ .ProjectName }}_{{ .Version }}_{{ .Os }}_{{ .Arch }}"
# 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
# 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.
# You can also set it to a custom folder name.
# Default is false.
wrap_in_directory: true
2017-09-10 17:07:28 -03:00
# Archive format. Valid options are `tar.gz`, `zip` and `binary`.
# 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 17:07:28 -03:00
format: zip
# Can be used to change the archive formats for specific GOOSs.
2017-09-10 17:07:28 -03:00
# Most common use case is to archive as zip on Windows.
# Default is empty.
2017-09-10 17:07:28 -03:00
format_overrides:
- goos: windows
format: zip
# Additional files/globs you want to add to the archive.
# Defaults are any files matching `LICENCE*`, `LICENSE*`,
# `README*` and `CHANGELOG*` (case-insensitive).
2017-09-10 17:07:28 -03:00
files:
- LICENSE.txt
- README.md
- CHANGELOG.md
- docs/*
- design/*.png
2018-07-21 10:21:13 -03:00
- templates/**/*
2017-09-10 17:07:28 -03:00
```
2018-07-08 23:57:46 -07:00
> Learn more about the [name template engine](/templates).
2018-07-21 10:21:13 -03:00
You can add entire folders, its subfolders and files by using the glob notation,
for example: `myfolder/**/*`.
## 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)