2021-10-30 09:50:23 -03:00
|
|
|
# Name Templates
|
2018-07-08 23:57:46 -07:00
|
|
|
|
|
|
|
Several fields in GoReleaser's config file support templating.
|
|
|
|
|
|
|
|
Those fields are often suffixed with `_template`, but sometimes they may not
|
2021-02-11 16:31:46 -05:00
|
|
|
be. The documentation of each section should be explicit about which fields
|
|
|
|
support templating.
|
2018-07-08 23:57:46 -07:00
|
|
|
|
2022-09-17 00:13:09 -03:00
|
|
|
<!-- to format the tables, use: https://tabletomarkdown.com/format-markdown-table/ -->
|
|
|
|
|
2021-11-12 09:07:59 -03:00
|
|
|
## Common Fields
|
|
|
|
|
2020-08-25 15:25:06 -04:00
|
|
|
On fields that support templating, these fields are always available:
|
2018-07-08 23:57:46 -07:00
|
|
|
|
2022-09-17 00:13:09 -03:00
|
|
|
Key |Description
|
|
|
|
----------------------|--------------------------------------------------------------------------------------------------------------------
|
|
|
|
`.ProjectName` |the project name
|
|
|
|
`.Version` |the version being released[^version-prefix]
|
|
|
|
`.Branch` |the current git branch
|
|
|
|
`.PrefixedTag` |the current git tag prefixed with the monorepo config tag prefix (if any)
|
|
|
|
`.Tag` |the current git tag
|
|
|
|
`.PrefixedPreviousTag`|the previous git tag prefixed with the monorepo config tag prefix (if any)
|
|
|
|
`.PreviousTag` |the previous git tag, or empty if no previous tags
|
|
|
|
`.ShortCommit` |the git commit short hash
|
|
|
|
`.FullCommit` |the git commit full hash
|
|
|
|
`.Commit` |the git commit hash (deprecated)
|
|
|
|
`.CommitDate` |the UTC commit date in RFC 3339 format
|
|
|
|
`.CommitTimestamp` |the UTC commit date in Unix format
|
|
|
|
`.GitURL` |the git remote url
|
|
|
|
`.Major` |the major part of the version[^tag-is-semver]
|
|
|
|
`.Minor` |the minor part of the version[^tag-is-semver]
|
|
|
|
`.Patch` |the patch part of the version[^tag-is-semver]
|
|
|
|
`.Prerelease` |the prerelease part of the version, e.g. `beta`[^tag-is-semver]
|
|
|
|
`.RawVersion` |composed of `{Major}.{Minor}.{Patch}` [^tag-is-semver]
|
|
|
|
`.ReleaseNotes` |the generated release notes, available after the changelog step has been executed
|
|
|
|
`.IsSnapshot` |`true` if `--snapshot` is set, `false` otherwise
|
|
|
|
`.IsNightly` |`true` if `--nightly` is set, `false` otherwise
|
|
|
|
`.Env` |a map with system's environment variables
|
|
|
|
`.Date` |current UTC date in RFC 3339 format
|
|
|
|
`.Timestamp` |current UTC time in Unix format
|
|
|
|
`.ModulePath` |the go module path, as reported by `go list -m`
|
|
|
|
`incpatch "v1.2.4"` |increments the patch of the given version[^panic-if-not-semver]
|
|
|
|
`incminor "v1.2.4"` |increments the minor of the given version[^panic-if-not-semver]
|
|
|
|
`incmajor "v1.2.4"` |increments the major of the given version[^panic-if-not-semver]
|
|
|
|
`.ReleaseURL` |the current release download url[^scm-release-url]
|
|
|
|
`.Summary` |the git summary, e.g. `v1.0.0-10-g34f56g3`[^git-summary]
|
|
|
|
`.PrefixedSummary` |the git summary prefixed with the monorepo config tag prefix (if any)
|
|
|
|
`.TagSubject` |the annotated tag message subject, or the message subject of the commit it points out[^git-tag-subject]. Since v1.2.
|
|
|
|
`.TagContents` |the annotated tag message, or the message of the commit it points out[^git-tag-body]. Since v1.2.
|
|
|
|
`.TagBody` |the annotated tag message's body, or the message's body of the commit it points out[^git-tag-body]. Since v1.2.
|
|
|
|
`.Runtime.Goos` |equivalent to `runtime.GOOS`. Since v1.5.
|
|
|
|
`.Runtime.Goarch` |equivalent to `runtime.GOARCH`. Since v1.5.
|
|
|
|
|
|
|
|
[^version-prefix]: The `v` prefix is stripped, and it might be changed in
|
|
|
|
`snapshot` and `nightly` builds.
|
|
|
|
[^tag-is-semver]: Assuming `Tag` is a valid a SemVer, otherwise empty/zeroed.
|
|
|
|
[^panic-if-not-semver]: Will panic if not a semantic version.
|
|
|
|
[^scm-release-url]: Composed of the current SCM's download URL and current tag.
|
|
|
|
For instance, on GitHub, it'll be
|
|
|
|
`https://github.com/{owner}/{repo}/releases/tag/{tag}`.
|
|
|
|
[^git-summary]: It is generated by `git describe --dirty --always --tags`, the
|
|
|
|
format will be `{Tag}-$N-{CommitSHA}`
|
|
|
|
[^git-tag-subject]: As reported by `git tag -l --format='%(contents:subject)'`
|
|
|
|
[^git-tag-body]: As reported by `git tag -l --format='%(contents)'`
|
2018-07-08 23:57:46 -07:00
|
|
|
|
2021-11-12 09:07:59 -03:00
|
|
|
## Single-artifact extra fields
|
|
|
|
|
2018-07-08 23:57:46 -07:00
|
|
|
On fields that are related to a single artifact (e.g., the binary name), you
|
|
|
|
may have some extra fields:
|
|
|
|
|
2022-09-17 00:13:09 -03:00
|
|
|
Key |Description
|
|
|
|
---------------|--------------------------------------------
|
|
|
|
`.Os` |`GOOS`[^archive-replacementes]
|
|
|
|
`.Arch` |`GOARCH`[^archive-replacementes]
|
|
|
|
`.Arm` |`GOARM`[^archive-replacementes]
|
|
|
|
`.Mips` |`GOMIPS`[^archive-replacementes]
|
|
|
|
`.Amd64` |`GOAMD64`[^archive-replacementes]
|
|
|
|
`.Binary` |binary name
|
|
|
|
`.ArtifactName`|archive name
|
|
|
|
`.ArtifactPath`|absolute path to artifact
|
|
|
|
`.ArtifactExt` |binary extension (e.g. `.exe`). Since v1.11.
|
2021-11-06 16:44:59 -03:00
|
|
|
|
2022-09-17 00:13:09 -03:00
|
|
|
[^archive-replacementes]: Might have been replaced by `archives.replacements`.
|
2018-07-08 23:57:46 -07:00
|
|
|
|
2021-11-12 09:07:59 -03:00
|
|
|
## nFPM extra fields
|
|
|
|
|
|
|
|
On the nFPM name template field, you can use those extra fields as well:
|
2020-03-22 13:54:47 -03:00
|
|
|
|
2022-09-17 00:13:09 -03:00
|
|
|
Key |Description
|
|
|
|
-----------------------|--------------------------------------------------------------
|
|
|
|
`.Release` |release from the nfpm config
|
|
|
|
`.Epoch` |epoch from the nfpm config
|
|
|
|
`.PackageName` |package the name. Same as `ProjectName` if not overridden.
|
|
|
|
`.ConventionalFileName`|conventional package file name as provided by nFPM[^arm-names]
|
2021-12-21 13:50:21 -03:00
|
|
|
|
2022-09-17 00:13:09 -03:00
|
|
|
[^arm-names]: Please beware: some OSs might have the same names for different
|
|
|
|
ARM versions, for example, for Debian both ARMv6 and ARMv7 are called `armhf`.
|
|
|
|
Make sure that's not your case otherwise you might end up with colliding
|
|
|
|
names. It also does not handle multiple GOAMD64 versions.
|
2021-11-12 09:07:59 -03:00
|
|
|
|
|
|
|
## Functions
|
2020-03-22 13:54:47 -03:00
|
|
|
|
2018-07-08 23:57:46 -07:00
|
|
|
On all fields, you have these available functions:
|
|
|
|
|
2022-09-17 00:13:09 -03:00
|
|
|
Usage |Description
|
|
|
|
------------------------------|------------------------------------------------------------------------------------------------------------------------------
|
|
|
|
`replace "v1.2" "v" ""` |replaces all matches. See [ReplaceAll](https://golang.org/pkg/strings/#ReplaceAll)
|
|
|
|
`split "1.2" "."` |split string at separator. See [Split](https://golang.org/pkg/strings/#Split). Since v1.11.
|
|
|
|
`time "01/02/2006"` |current UTC time in the specified format (this is not deterministic, a new time for every call)
|
|
|
|
`tolower "V1.2"` |makes input string lowercase. See [ToLower](https://golang.org/pkg/strings/#ToLower)
|
|
|
|
`toupper "v1.2"` |makes input string uppercase. See [ToUpper](https://golang.org/pkg/strings/#ToUpper)
|
|
|
|
`trim " v1.2 "` |removes all leading and trailing white space. See [TrimSpace](https://golang.org/pkg/strings/#TrimSpace)
|
|
|
|
`trimprefix "v1.2" "v"` |removes provided leading prefix string, if present. See [TrimPrefix](https://golang.org/pkg/strings/#TrimPrefix)
|
|
|
|
`trimsuffix "1.2v" "v"` |removes provided trailing suffix string, if present. See [TrimSuffix](https://pkg.go.dev/strings#TrimSuffix)
|
|
|
|
`dir .Path` |returns all but the last element of path, typically the path's directory. See [Dir](https://golang.org/pkg/path/filepath/#Dir)
|
|
|
|
`abs .ArtifactPath` |returns an absolute representation of path. See [Abs](https://golang.org/pkg/path/filepath/#Abs)
|
|
|
|
`filter "text" "regex"` |keeps only the lines matching the given regex, analogous to `grep -E`. Since v1.6.
|
|
|
|
`reverseFilter "text" "regex"`|keeps only the lines **not** matching the given regex, analogous to `grep -vE`. Since v1.6.
|
2018-07-08 23:57:46 -07:00
|
|
|
|
|
|
|
With all those fields, you may be able to compose the name of your artifacts
|
|
|
|
pretty much the way you want:
|
|
|
|
|
|
|
|
```yaml
|
2019-11-07 18:49:36 +01:00
|
|
|
example_template: '{{ tolower .ProjectName }}_{{ .Env.USER }}_{{ time "2006" }}'
|
2018-07-08 23:57:46 -07:00
|
|
|
```
|
|
|
|
|
|
|
|
For example, if you want to add the go version to some artifact:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
foo_template: 'foo_{{ .Env.GOVERSION }}'
|
|
|
|
```
|
|
|
|
|
|
|
|
And then you can run:
|
|
|
|
|
2019-03-24 20:10:30 -03:00
|
|
|
```sh
|
2018-07-08 23:57:46 -07:00
|
|
|
GOVERSION_NR=$(go version | awk '{print $3;}') goreleaser
|
|
|
|
```
|
|
|
|
|
2020-05-10 19:47:55 -03:00
|
|
|
!!! warning
|
2020-05-10 19:37:28 -03:00
|
|
|
Note that those are hypothetical examples and the fields `foo_template` and
|
|
|
|
`example_template` are not valid GoReleaser configurations.
|
2021-05-30 17:59:10 +00:00
|
|
|
|
|
|
|
## Custom variables
|
|
|
|
|
2021-09-22 23:30:16 -03:00
|
|
|
!!! success "GoReleaser Pro"
|
|
|
|
Custom template variables support is a [GoReleaser Pro feature](/pro/).
|
|
|
|
|
2022-09-17 00:13:09 -03:00
|
|
|
You can also declare custom variables. This feature is specially useful with
|
|
|
|
[includes](/customization/includes/), so you can have more generic configuration
|
|
|
|
files.
|
2021-05-30 17:59:10 +00:00
|
|
|
|
|
|
|
Usage is as simple as you would expect:
|
|
|
|
|
|
|
|
```yaml
|
2021-12-23 01:52:01 +01:00
|
|
|
# .goreleaser.yaml
|
2021-05-30 17:59:10 +00:00
|
|
|
variables:
|
|
|
|
description: my project description
|
|
|
|
somethingElse: yada yada yada
|
2021-09-22 23:30:16 -03:00
|
|
|
empty: ""
|
2021-05-30 17:59:10 +00:00
|
|
|
```
|
|
|
|
|
2022-01-20 16:22:54 -03:00
|
|
|
And then you can use those fields as `{{ .Var.description }}`, for example.
|
2022-09-11 16:54:51 -03:00
|
|
|
|