From: Shenghou Ma Date: Sat, 17 Jan 2015 02:07:23 +0000 (-0500) Subject: misc/makerelease: workaround the go install -a restriction on release branches X-Git-Tag: go1.5beta1~2323 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=30e910197a87773cec9ca53b4e0e5f6114bbd9bf;p=gostls13.git misc/makerelease: workaround the go install -a restriction on release branches Fixes #9619. Change-Id: I71931b0d546163e5451d7d72e552b08540e3c2a7 Reviewed-on: https://go-review.googlesource.com/2995 Reviewed-by: Andrew Gerrand --- diff --git a/misc/makerelease/makerelease.go b/misc/makerelease/makerelease.go index 0af0ebf2c9..4b6e866b44 100644 --- a/misc/makerelease/makerelease.go +++ b/misc/makerelease/makerelease.go @@ -277,13 +277,27 @@ func (b *Build) Do() error { if b.OS == "windows" { goCmd += ".exe" } + // Because on release branches, go install -a std is a NOP, + // we have to resort to delete pkg/$GOOS_$GOARCH, install -race, + // and then reinstall std so that we're not left with a slower, + // race-enabled cmd/go, etc. + goPkg := filepath.Join(b.root, "pkg", b.OS+"_"+b.Arch) + err = os.RemoveAll(goPkg) + if err != nil { + return err + } + _, err = b.run(src, goCmd, "tool", "dist", "install", "runtime") + if err != nil { + return err + } _, err = b.run(src, goCmd, "install", "-race", "std") if err != nil { return err } - // Re-install std without -race, so that we're not left - // with a slower, race-enabled cmd/go, etc. - _, err = b.run(src, goCmd, "install", "-a", "std") + _, err = b.run(src, goCmd, "install", "std") + if err != nil { + return err + } // Re-building go command leaves old versions of go.exe as go.exe~ on windows. // See (*builder).copyFile in $GOROOT/src/cmd/go/build.go for details. // Remove it manually.