require 'formula' class Go < Formula homepage 'http://golang.org' head 'https://go.googlecode.com/hg/' url 'https://go.googlecode.com/files/go1.2.src.tar.gz' version '1.2' sha1 '7dd2408d40471aeb30a9e0b502c6717b5bf383a5' bottle do sha1 '8545bca00ef68365f021acff29573a63cad79625' => :mavericks sha1 'cd1bf484aba6a0ba04d75eb2d5e6eee2593631e8' => :mountain_lion sha1 '18bb16cf44771e5065a017358853ad59c7f6a3ca' => :lion end option 'cross-compile-all', "Build the cross-compilers and runtime support for all supported platforms" option 'cross-compile-common', "Build the cross-compilers and runtime support for darwin, linux and windows" option 'without-cgo', "Build without cgo" def install # install the completion scripts bash_completion.install 'misc/bash/go' => 'go-completion.bash' zsh_completion.install 'misc/zsh/go' => 'go' # host platform (darwin) must come last in the targets list if build.include? 'cross-compile-all' targets = [ ['linux', ['386', 'amd64', 'arm']], ['freebsd', ['386', 'amd64']], ['netbsd', ['386', 'amd64']], ['openbsd', ['386', 'amd64']], ['windows', ['386', 'amd64']], ['darwin', ['386', 'amd64']], ] elsif build.include? 'cross-compile-common' targets = [ ['linux', ['386', 'amd64', 'arm']], ['windows', ['386', 'amd64']], ['darwin', ['386', 'amd64']], ] else targets = [['darwin', ['']]] end # The version check is due to: # http://codereview.appspot.com/5654068 (buildpath/'VERSION').write('default') if build.head? cd 'src' do targets.each do |os, archs| cgo_enabled = os == 'darwin' && build.with?('cgo') ? "1" : "0" archs.each do |arch| ENV['GOROOT_FINAL'] = libexec ENV['GOOS'] = os ENV['GOARCH'] = arch ENV['CGO_ENABLED'] = cgo_enabled system "./make.bash", "--no-clean" end end end (buildpath/'pkg/obj').rmtree libexec.install Dir['*'] bin.install_symlink Dir["#{libexec}/bin/*"] end def caveats; <<-EOS.undent As of go 1.2, a valid GOPATH is required to use the `go get` command: http://golang.org/doc/code.html#GOPATH `go vet` and `go doc` are now part of the go.tools sub repo: http://golang.org/doc/go1.2#go_tools_godoc To get `go vet` and `go doc` run: go get code.google.com/p/go.tools/cmd/godoc go get code.google.com/p/go.tools/cmd/vet You may wish to add the GOROOT-based install location to your PATH: export PATH=$PATH:#{`#{bin}/go env GOROOT`.chomp}/bin EOS end test do (testpath/'hello.go').write <<-EOS.undent package main import "fmt" func main() { fmt.Println("Hello World") } EOS # Run go fmt check for no errors then run the program. # This is a a bare minimum of go working as it uses fmt, build, and run. system "#{bin}/go", "fmt", "hello.go" assert_equal "Hello World\n", `#{bin}/go run hello.go` end end