1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-01-06 03:13:48 +02:00
Deliver Go binaries as fast and easily as possible https://goreleaser.com/
Go to file
Carlos Alexandro Becker 7d7a1d39c8
fixed import
2016-12-30 16:52:50 -02:00
config golint 2016-12-30 12:41:59 -02:00
pipeline fixed import 2016-12-30 16:52:50 -02:00
split golint 2016-12-30 12:41:59 -02:00
uname fixed naming 2016-12-30 16:52:45 -02:00
.gitignore glide and travis 2016-12-28 23:30:14 -02:00
.travis.yml moving 2016-12-28 23:31:53 -02:00
glide.lock removed pkg/errors 2016-12-29 18:01:18 -02:00
glide.yaml multiple builds 2016-12-29 14:13:09 -02:00
goreleaser.yml fixed releasing 2016-12-29 10:15:08 -02:00
LICENSE.md readme, license and shit 2016-12-28 22:55:23 -02:00
main.go golint 2016-12-30 12:41:59 -02:00
README.md go report card 2016-12-30 12:03:36 -02:00

GoReleaser Build Status Go Report Card Powered By: GoReleaser

Deliver Go binaries as fast and easy as possible.

GoReleaser builds Go binaries for several platforms, creates a github release and then push a homebrew formulae to a repository. All that wrapped in your favorite CI.

How it works?

The idea started with a simple shell script, but it quickly became more complex and I also wanted to publish binaries via homebrew.

So, the all-new goreleaser was born.

Usage

Basically, you need to create a goreleaser.yml file in the root of your repository. A minimal config would look like this:

repo: user/repo
binary_name: my-binary

This will build main.go file as my-binary, for Darwin and Linux, x86_64 and i386, packaging the binary, LICENSE.md and README.md and publish a new github release in the user/repo repository with the .tar.gz files there.

Homebrew

To push it to a homebrew repo, just add a brew section:

repo: user/repo
binary_name: my-binary
brew:
  repo: user/homebrew-formulae
  caveats: "Optional caveats to add to the formulae"

Build customization

Just add a build section

repo: user/repo
binary_name: my-binary
build:
  main: ./cmd/main.go
  oses:
    - darwin
    - freebsd
  arches:
    - amd64

oses and arches should be in GOOS/GOARCH-compatible format.

Add more files

You might also want to change the files that are packaged by adding a files section:

repo: user/repo
binary_name: my-binary
files:
  - LICENSE.txt
  - README.md
  - CHANGELOG.md

Wire it with travis-ci

You may want to wire this to auto-deploy your new tags on travis, for examepl:

after_success:
  test ! -z "$TRAVIS_TAG" && curl -s https://raw.githubusercontent.com/goreleaser/get/master/latest | bash

How the end result looks like

The release on github looks pretty much like this:

image

And the homebrew formulae would look like:

class Antibody < Formula
  desc "A faster and simpler antigen written in Golang."
  homepage "http://getantibody.github.io"
  url "https://github.com/getantibody/antibody/releases/download/v2.2.2/antibody_#{%x(uname -s).gsub(/\n/, '')}_#{%x(uname -m).gsub(/\n/, '')}.tar.gz"
  head "https://github.com/getantibody/antibody.git"
  version "v2.2.2"

  def install
    bin.install "antibody"
  end

  def caveats
    "To start using antibody, you need to add `source <(antibody init)` to your `~/.zshrc`."
  end
end

Badges

Feel free to use it in your own projects:

[![Powered By: GoReleaser](https://img.shields.io/badge/powered%20by-goreleaser-green.svg?style=flat-square)](https://github.com/goreleaser)