diff --git a/src/cmd/dist/build.go b/src/cmd/dist/build.go index 634c52c3b0fe554fab7ef18de9a626849ea81bb5..39a88ccab591f3cfa2f985550c0d2ba19583900a 100644 --- a/src/cmd/dist/build.go +++ b/src/cmd/dist/build.go @@ -322,18 +322,15 @@ func findgoversion() string { // isGitRepo reports whether the working directory is inside a Git repository. func isGitRepo() bool { - p := ".git" - for { - fi, err := os.Stat(p) - if os.IsNotExist(err) { - p = filepath.Join("..", p) - continue - } - if err != nil || !fi.IsDir() { - return false - } - return true - } + // NB: simply checking the exit code of `git rev-parse --git-dir` would + // suffice here, but that requires deviating from the infrastructure + // provided by `run`. + gitDir := chomp(run(goroot, 0, "git", "rev-parse", "--git-dir")) + if !filepath.IsAbs(gitDir) { + gitDir = filepath.Join(goroot, gitDir) + } + fi, err := os.Stat(gitDir) + return err == nil && fi.IsDir() } /*