Add GOEXE to support building with different versions of `go`
authorMichael Henderson <mdhender@mdhender.com>
Sat, 15 Jul 2017 21:18:38 +0000 (15:18 -0600)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Sat, 15 Jul 2017 22:35:15 +0000 (00:35 +0200)
Add a variable to the makefile and benchmark scripts to let users change the command used to build. Doesn't impact tools like govendor.

Makefile
bench.sh
benchSite.sh

index 4508ab7cfd3cf2c482871b7e88432c464f986c39..0518967cea0af979a4dbd4f5aa76d3b07ca3b4d9 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -6,21 +6,24 @@ BUILD_DATE = `date +%FT%T%z`
 LDFLAGS = -ldflags "-X ${PACKAGE}/hugolib.CommitHash=${COMMIT_HASH} -X ${PACKAGE}/hugolib.BuildDate=${BUILD_DATE}"
 NOGI_LDFLAGS = -ldflags "-X ${PACKAGE}/hugolib.BuildDate=${BUILD_DATE}"
 
+# allow user to override go executable by running as GOEXE=xxx make ... on unix-like systems
+GOEXE ?= go
+
 .PHONY: vendor docker check fmt lint test test-race vet test-cover-html help
 .DEFAULT_GOAL := help
 
 vendor: ## Install govendor and sync Hugo's vendored dependencies
-       go get github.com/kardianos/govendor
+       ${GOEXE} get github.com/kardianos/govendor
        govendor sync ${PACKAGE}
 
 hugo: vendor ## Build hugo binary
-       go build ${LDFLAGS} ${PACKAGE}
+       ${GOEXE} build ${LDFLAGS} ${PACKAGE}
 
 hugo-race: vendor ## Build hugo binary with race detector enabled
-       go build -race ${LDFLAGS} ${PACKAGE}
+       ${GOEXE} build -race ${LDFLAGS} ${PACKAGE}
 
 install: vendor ## Install hugo binary
-       go install ${LDFLAGS} ${PACKAGE}
+       ${GOEXE} install ${LDFLAGS} ${PACKAGE}
 
 hugo-no-gitinfo: LDFLAGS = ${NOGI_LDFLAGS}
 hugo-no-gitinfo: vendor hugo ## Build hugo without git info
@@ -74,7 +77,7 @@ test-cover-html: ## Generate test coverage report
        $(foreach pkg,$(PACKAGES),\
                govendor test -coverprofile=coverage.out -covermode=count $(pkg);\
                tail -n +2 coverage.out >> coverage-all.out;)
-       go tool cover -html=coverage-all.out
+       ${GOEXE} tool cover -html=coverage-all.out
 
 check-vendor: ## Verify that vendored packages match git HEAD
        @git diff-index --quiet HEAD vendor/ || (echo "check-vendor target failed: vendored packages out of sync" && echo && git diff vendor/ && exit 1)
index 367a744030bcbe95ecdf634b9045175d02cd9e14..c6a20a7e3158764f582eb56ccc4acdf82202db01 100755 (executable)
--- a/bench.sh
+++ b/bench.sh
@@ -1,5 +1,7 @@
 #!/usr/bin/env bash
 
+# allow user to override go executable by running as GOEXE=xxx make ...
+GOEXE="${GOEXE-go}"
 
 # Convenience script to
 # - For a given branch
@@ -26,10 +28,10 @@ BRANCH=$1
 PACKAGE=$2
 
 git checkout $BRANCH
-go test -test.run=NONE -bench="$benchFilter" -test.benchmem=true ./$PACKAGE > /tmp/bench-$PACKAGE-$BRANCH.txt
+"${GOEXE}" test -test.run=NONE -bench="$benchFilter" -test.benchmem=true ./$PACKAGE > /tmp/bench-$PACKAGE-$BRANCH.txt
 
 git checkout master
-go test -test.run=NONE -bench="$benchFilter" -test.benchmem=true ./$PACKAGE > /tmp/bench-$PACKAGE-master.txt
+"${GOEXE}" test -test.run=NONE -bench="$benchFilter" -test.benchmem=true ./$PACKAGE > /tmp/bench-$PACKAGE-master.txt
 
 
-benchcmp /tmp/bench-$PACKAGE-master.txt /tmp/bench-$PACKAGE-$BRANCH.txt
\ No newline at end of file
+benchcmp /tmp/bench-$PACKAGE-master.txt /tmp/bench-$PACKAGE-$BRANCH.txt
index 8130559f5d413fc925ef2e8099167bc7208ccf8c..fd088a5ecc8b3cb37a7b5f9a66823a900146b3de 100755 (executable)
@@ -1,9 +1,12 @@
 #!/bin/bash
 
+# allow user to override go executable by running as GOEXE=xxx make ...
+GOEXE="${GOEXE-go}"
+
 # Send in a regexp mathing the benchmarks you want to run, i.e. './benchSite.sh "YAML"'. 
 # Note the quotes, which will be needed for more complex expressions.
 # The above will run all variations, but only for front matter YAML.
 
 echo "Running with BenchmarkSiteBuilding/${1}"
 
-go test -run="NONE" -bench="BenchmarkSiteBuilding/${1}$" -test.benchmem=true ./hugolib -memprofile mem.prof -cpuprofile cpu.prof
\ No newline at end of file
+"${GOEXE}" test -run="NONE" -bench="BenchmarkSiteBuilding/${1}$" -test.benchmem=true ./hugolib -memprofile mem.prof -cpuprofile cpu.prof