From f3c64d0740cd2a6a3eab3bebd71eb9c159d7212f Mon Sep 17 00:00:00 2001 From: Alexander Neumann Date: Tue, 25 Aug 2015 22:20:53 +0200 Subject: [PATCH 1/2] build.go: use new combined version string Previously, when a VERSION file exists it takes precendence over the git version. This is unfortunate because all restic binaries compiled from a git checkout will just identify as the latest release (e.g. '0.1.0'), regardeless of any commits on top of it. This commit adds a combined version string by using the contents of the VERSION file, and append the current git version returned by `git describe` if available, e.g.: 0.1.0 (v0.1.0-6-gb188217-dirty). --- build.go | 29 +++++++++++++++++++++-------- 1 file changed, 21 insertions(+), 8 deletions(-) diff --git a/build.go b/build.go index 05c930ae3..ccfb18084 100644 --- a/build.go +++ b/build.go @@ -200,17 +200,30 @@ func test(gopath string, args ...string) error { return cmd.Run() } -// getVersion returns a version string, either from the file VERSION in the -// current directory or from git. +// getVersion returns a version string which is a combination of the contents +// of the file VERSION in the current directory and the version from git (if +// available). func getVersion() string { - v, err := ioutil.ReadFile("VERSION") - version := strings.TrimSpace(string(v)) - if err == nil { - verbosePrintf("version from file 'VERSION' is %s\n", version) - return version + buf, err := ioutil.ReadFile("VERSION") + if err != nil { + verbosePrintf("error reading file VERSION: %v\n", err) + } + versionFile := strings.TrimSpace(string(buf)) + verbosePrintf("version from file 'VERSION' is %q\n", versionFile) + + versionGit := gitVersion() + verbosePrintf("version from file 'VERSION' is %q\n", versionGit) + + if versionFile == "" && versionGit == "" { + return "unknown" } - return gitVersion() + version := versionFile + if versionGit != "" { + version += " (" + versionGit + ")" + } + + return version } // gitVersion returns a version string that identifies the currently checked From 39a82d951bb269ae7adad6c83f344a0e9721badc Mon Sep 17 00:00:00 2001 From: Alexander Neumann Date: Wed, 26 Aug 2015 20:13:00 +0200 Subject: [PATCH 2/2] Refactor getVersion(), address code review comments --- build.go | 44 +++++++++++++++++++++++++------------------- 1 file changed, 25 insertions(+), 19 deletions(-) diff --git a/build.go b/build.go index ccfb18084..5d00768d2 100644 --- a/build.go +++ b/build.go @@ -200,35 +200,41 @@ func test(gopath string, args ...string) error { return cmd.Run() } +// getVersion returns the version string from the file VERSION in the current +// directory. +func getVersionFromFile() string { + buf, err := ioutil.ReadFile("VERSION") + if err != nil { + verbosePrintf("error reading file VERSION: %v\n", err) + return "" + } + + return strings.TrimSpace(string(buf)) +} + // getVersion returns a version string which is a combination of the contents // of the file VERSION in the current directory and the version from git (if // available). func getVersion() string { - buf, err := ioutil.ReadFile("VERSION") - if err != nil { - verbosePrintf("error reading file VERSION: %v\n", err) - } - versionFile := strings.TrimSpace(string(buf)) - verbosePrintf("version from file 'VERSION' is %q\n", versionFile) + versionFile := getVersionFromFile() + versionGit := getVersionFromGit() - versionGit := gitVersion() - verbosePrintf("version from file 'VERSION' is %q\n", versionGit) + verbosePrintf("version from file 'VERSION' is %q, version from git %q\n", + versionFile, versionGit) - if versionFile == "" && versionGit == "" { - return "unknown" + switch { + case versionFile == "": + return versionGit + case versionGit == "": + return versionFile } - version := versionFile - if versionGit != "" { - version += " (" + versionGit + ")" - } - - return version + return fmt.Sprintf("%s (%s)", versionFile, versionGit) } -// gitVersion returns a version string that identifies the currently checked -// out git commit. -func gitVersion() string { +// getVersionFromGit returns a version string that identifies the currently +// checked out git commit. +func getVersionFromGit() string { cmd := exec.Command("git", "describe", "--long", "--tags", "--dirty", "--always") out, err := cmd.Output()