diff options
author | Arba Sasmoyo <arba.sasmoyo@gmail.com> | 2017-11-13 04:00:18 +0800 |
---|---|---|
committer | Péter Szilágyi <peterke@gmail.com> | 2017-11-13 04:00:18 +0800 |
commit | f47adc9ea8f16544a023ea9b67d1ed320750c5e7 (patch) | |
tree | cb3ac5d8294096c702c0a38ae689e729453a187b /internal/build/env.go | |
parent | 86f6568f6618945b19057553ec32690d723da982 (diff) | |
download | dexon-f47adc9ea8f16544a023ea9b67d1ed320750c5e7.tar dexon-f47adc9ea8f16544a023ea9b67d1ed320750c5e7.tar.gz dexon-f47adc9ea8f16544a023ea9b67d1ed320750c5e7.tar.bz2 dexon-f47adc9ea8f16544a023ea9b67d1ed320750c5e7.tar.lz dexon-f47adc9ea8f16544a023ea9b67d1ed320750c5e7.tar.xz dexon-f47adc9ea8f16544a023ea9b67d1ed320750c5e7.tar.zst dexon-f47adc9ea8f16544a023ea9b67d1ed320750c5e7.zip |
.dockerignore, internal/build: Read git information directly from file (#15458)
* .dockerignore, internal/build: Read git information directly from file
This commit changes the way of retrieving git commit and branch for build
environment from running git command to reading git files directly.
This commit also adds required git files into Docker build context.
fixes: #15346
* .dockerignore: workaround for including some files in .git
Diffstat (limited to 'internal/build/env.go')
-rw-r--r-- | internal/build/env.go | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/internal/build/env.go b/internal/build/env.go index c47681ebe..793242fcf 100644 --- a/internal/build/env.go +++ b/internal/build/env.go @@ -82,18 +82,21 @@ func Env() Environment { // LocalEnv returns build environment metadata gathered from git. func LocalEnv() Environment { env := applyEnvFlags(Environment{Name: "local", Repo: "ethereum/go-ethereum"}) - if _, err := os.Stat(".git"); err != nil { + head := ReadGitFile("HEAD") + if splits := strings.Split(head, " "); len(splits) == 2 { + head = splits[1] + } else { return env } if env.Commit == "" { - env.Commit = RunGit("rev-parse", "HEAD") + env.Commit = ReadGitFile(head) } if env.Branch == "" { - if b := RunGit("rev-parse", "--abbrev-ref", "HEAD"); b != "HEAD" { - env.Branch = b + if head != "HEAD" { + env.Branch = strings.TrimLeft(head, "refs/heads/") } } - if env.Tag == "" { + if info, err := os.Stat(".git/objects"); err == nil && info.IsDir() && env.Tag == "" { env.Tag = firstLine(RunGit("tag", "-l", "--points-at", "HEAD")) } return env |