make.go: remove some unused code, address TODOs, bump required Go

Signed-off-by: Brad Fitzpatrick <brad@danga.com>
This commit is contained in:
Brad Fitzpatrick 2023-12-31 12:36:32 -08:00
parent 98dff16008
commit 2b8414f6ce
1 changed files with 16 additions and 65 deletions

81
make.go
View File

@ -184,7 +184,7 @@ func main() {
} }
cmd := exec.Command("go", args...) cmd := exec.Command("go", args...)
cmd.Env = cleanGoEnv() cmd.Env = goEnv()
if *static { if *static {
cmd.Env = append(cmd.Env, "CGO_ENABLED=0") cmd.Env = append(cmd.Env, "CGO_ENABLED=0")
} }
@ -215,7 +215,7 @@ func main() {
func actualBinDir() string { func actualBinDir() string {
cmd := exec.Command("go", "list", "-f", "{{.Target}}", "perkeep.org/cmd/pk") cmd := exec.Command("go", "list", "-f", "{{.Target}}", "perkeep.org/cmd/pk")
cmd.Env = cleanGoEnv() cmd.Env = goEnv()
cmd.Stderr = os.Stderr cmd.Stderr = os.Stderr
out, err := cmd.Output() out, err := cmd.Output()
if err != nil { if err != nil {
@ -441,56 +441,25 @@ func envPair(key, value string) string {
return fmt.Sprintf("%s=%s", key, value) return fmt.Sprintf("%s=%s", key, value)
} }
// TODO(mpl): we probably can get rid of cleanGoEnv now that "last in wins" for func goEnv() (ret []string) {
// duplicates in Env. ret = slices.Clone(os.Environ())
var cross bool
// cleanGoEnv returns a copy of the current environment with any variable listed
// in others removed. Also, when cross-compiling, it removes GOBIN and sets GOOS
// and GOARCH, and GOARM as needed.
func cleanGoEnv(others ...string) (clean []string) {
excl := make([]string, len(others))
for i, v := range others {
excl[i] = v + "="
}
Env:
for _, env := range os.Environ() {
for _, v := range excl {
if strings.HasPrefix(env, v) {
continue Env
}
}
// remove GOBIN if we're cross-compiling
if strings.HasPrefix(env, "GOBIN=") &&
(*buildOS != runtime.GOOS || *buildARCH != runtime.GOARCH) {
continue
}
// We skip these two as well, otherwise they'd take precedence over the
// ones appended below.
if *buildOS != runtime.GOOS && strings.HasPrefix(env, "GOOS=") {
continue
}
if *buildARCH != runtime.GOARCH && strings.HasPrefix(env, "GOARCH=") {
continue
}
// If we're building for ARM (regardless of cross-compiling or not), we reset GOARM
if *buildARCH == "arm" && strings.HasPrefix(env, "GOARM=") {
continue
}
clean = append(clean, env)
}
if *buildOS != runtime.GOOS { if *buildOS != runtime.GOOS {
clean = append(clean, envPair("GOOS", *buildOS)) ret = append(ret, envPair("GOOS", *buildOS))
cross = true
} }
if *buildARCH != runtime.GOARCH { if *buildARCH != runtime.GOARCH {
clean = append(clean, envPair("GOARCH", *buildARCH)) ret = append(ret, envPair("GOARCH", *buildARCH))
cross = true
}
if cross {
ret = append(ret, envPair("GOBIN", ""))
} }
// If we're building for ARM (regardless of cross-compiling or not), we reset GOARM // If we're building for ARM (regardless of cross-compiling or not), we reset GOARM
if *buildARCH == "arm" { if *buildARCH == "arm" {
clean = append(clean, envPair("GOARM", *buildARM)) ret = append(ret, envPair("GOARM", *buildARM))
} }
return return ret
} }
// fullSrcPath returns the full path concatenation // fullSrcPath returns the full path concatenation
@ -590,7 +559,7 @@ func verifyPerkeepRoot() {
// we can't rely on perkeep.org/cmd/pk with modules on as we have no assurance // we can't rely on perkeep.org/cmd/pk with modules on as we have no assurance
// the current dir is $GOPATH/src/perkeep.org, so we use ./cmd/pk instead. // the current dir is $GOPATH/src/perkeep.org, so we use ./cmd/pk instead.
cmd := exec.Command("go", "list", "-f", "{{.Target}}", "./cmd/pk") cmd := exec.Command("go", "list", "-f", "{{.Target}}", "./cmd/pk")
if os.Getenv("GO111MODULE") == "off" || *buildPublisherUI { if *buildPublisherUI {
// if we're building the webUI we need to be in "legacy" GOPATH mode, so in // if we're building the webUI we need to be in "legacy" GOPATH mode, so in
// $GOPATH/src/perkeep.org // $GOPATH/src/perkeep.org
if err := validateDirInGOPATH(pkRoot); err != nil { if err := validateDirInGOPATH(pkRoot); err != nil {
@ -644,7 +613,7 @@ func validateDirInGOPATH(dir string) error {
} }
const ( const (
goVersionMinor = 16 goVersionMinor = 21
) )
var validVersionRx = regexp.MustCompile(`go version go1\.(\d+)`) var validVersionRx = regexp.MustCompile(`go version go1\.(\d+)`)
@ -690,24 +659,6 @@ func verifyGoVersion() {
if minorVersion < goVersionMinor { if minorVersion < goVersionMinor {
log.Fatalf("Your version of Go (%s) is too old. Perkeep requires Go 1.%d or later.", string(out), goVersionMinor) log.Fatalf("Your version of Go (%s) is too old. Perkeep requires Go 1.%d or later.", string(out), goVersionMinor)
} }
}
// hostExeName returns the executable name
// for s on the currently running host OS.
func hostExeName(s string) string {
if runtime.GOOS == "windows" {
return s + ".exe"
}
return s
}
// copied from pkg/osutil/paths.go
func homeDir() string {
if runtime.GOOS == "windows" {
return os.Getenv("HOMEDRIVE") + os.Getenv("HOMEPATH")
}
return os.Getenv("HOME")
} }
func failIfCamlistoreOrgDir() { func failIfCamlistoreOrgDir() {