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

123 lines
3.3 KiB
Markdown
Raw Normal View History

2017-09-10 17:07:28 -03:00
---
title: Homebrew
series: customization
hideFromIndex: true
weight: 90
2017-09-10 17:07:28 -03:00
---
After releasing to GitHub, GoReleaser can generate and publish a _homebrew-tap_
2017-09-10 17:07:28 -03:00
recipe into a repository that you have access to.
The `brew` section specifies how the formula should be created.
2017-09-10 17:07:28 -03:00
You can check the
[Homebrew documentation](https://github.com/Homebrew/brew/blob/master/docs/How-to-Create-and-Maintain-a-Tap.md)
and the
[formula cookbook](https://github.com/Homebrew/brew/blob/master/docs/Formula-Cookbook.md)
for more details.
```yml
# .goreleaser.yml
brew:
2018-07-08 23:57:46 -07:00
# Name template of the recipe
# Default to project name
name: myproject
2017-09-10 17:07:28 -03:00
# Reporitory to push the tap to.
github:
owner: user
name: homebrew-tap
# Template for the url.
# Default is "https://github.com/<repo_owner>/<repo_name>/releases/download/{{ .Tag }}/{{ .ArtifactName }}"
url_template: "http://github.mycompany.com/foo/bar/releases/{{ .Tag }}/{{ .ArtifactName }}"
2018-01-17 19:28:15 -02:00
# Allows you to set a custom download strategy.
# Default is empty.
download_strategy: GitHubPrivateRepositoryReleaseDownloadStrategy
# Git author used to commit to the repository.
# Defaults are shown.
commit_author:
name: goreleaserbot
email: goreleaser@carlosbecker.com
2017-09-10 17:07:28 -03:00
# Folder inside the repository to put the formula.
# Default is the root folder.
folder: Formula
# Caveats for the user of your binary.
# Default is empty.
caveats: "How to use this binary"
# Your app's homepage.
# Default is empty.
2017-09-10 17:07:28 -03:00
homepage: "https://example.com/"
# Your app's description.
# Default is empty.
2017-09-10 17:07:28 -03:00
description: "Software to create fast and easy drum rolls."
2018-01-10 19:22:37 -02:00
# Setting this will prevent goreleaser to actually try to commit the updated
# formula - instead, the formula file will be stored on the dist folder only,
# leaving the responsibility of publishing it to the user.
2018-01-17 19:28:15 -02:00
# Default is false.
2018-01-10 19:22:37 -02:00
skip_upload: true
# Packages your package depends on.
2017-09-10 17:07:28 -03:00
dependencies:
- git
- zsh
# Packages that conflict with your package.
2017-09-10 17:07:28 -03:00
conflicts:
- svn
- bash
# Specify for packages that run as a service.
# Default is empty.
2017-09-10 17:07:28 -03:00
plist: |
<?xml version="1.0" encoding="UTF-8"?>
...
# So you can `brew test` your formula.
# Default is empty.
2017-09-10 17:07:28 -03:00
test: |
system "#{bin}/program --version"
...
# Custom install script for brew.
# Default is 'bin.install "program"'.
2017-09-10 17:07:28 -03:00
install: |
bin.install "program"
...
```
2018-07-08 23:57:46 -07:00
> Learn more about the [name template engine](/templates).
2017-09-10 17:07:28 -03:00
By defining the `brew` section, GoReleaser will take care of publishing the
Homebrew tap.
Assuming that the current tag is `v1.2.3`, the above configuration will generate a
2017-09-10 17:07:28 -03:00
`program.rb` formula in the `Formula` folder of `user/homebrew-tap` repository:
```rb
class Program < Formula
desc "How to use this binary"
homepage "https://github.com/user/repo"
url "https://github.com/user/repo/releases/download/v1.2.3/program_v1.2.3_macOs_64bit.zip"
version "v1.2.3"
sha256 "9ee30fc358fae8d248a2d7538957089885da321dca3f09e3296fe2058e7fff74"
depends_on "git"
depends_on "zsh"
def install
bin.install "program"
end
end
```
**Important**": Note that GoReleaser does not yet generate a valid
homebrew-core formula. The generated formulas are meant to be published as
[homebrew taps](https://docs.brew.sh/Taps.html), and in their current
2017-09-10 17:07:28 -03:00
form will not be accepted in any of the official homebrew repositories.