Skip to content

Commit

Permalink
Parse Go SDK version out of go version instead of VERSION
Browse files Browse the repository at this point in the history
The top-level `VERSION` file does not exist in all Go SDK distributions,
e.g. those shipped by Debian or Fedora.
  • Loading branch information
fmeum committed Sep 15, 2022
1 parent ba48db5 commit bc8512c
Showing 1 changed file with 11 additions and 6 deletions.
17 changes: 11 additions & 6 deletions go/private/sdk.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -302,13 +302,18 @@ def _detect_sdk_platform(ctx, goroot):
return platforms[0]

def _detect_sdk_version(ctx, goroot):
path = goroot + "/VERSION"
version_contents = ctx.read(path)

# VERSION file has version prefixed by go, eg. go1.18.3
version = version_contents[2:]
go_binary_path = goroot + "/bin/go"
result = ctx.execute([go_binary_path, "version"])
if result.return_code != 0:
fail("Could not detect SDK version: '%s version' exited with exit code %d" % (go_binary_path, result.return_code))

# go version output is of the form "go version go1.18.3 linux/amd64"
output_parts = result.stdout.split(" ")
if len(output_parts) < 3 or not output_parts[2].startswith("go"):
fail("Could not parse SDK version from '%s version' output: %s" % (go_binary_path, result.stdout))
version = output_parts[2][len("go"):]
if _parse_version(version) == None:
fail("Could not parse SDK version from version file (%s): %s" % (path, version_contents))
fail("Could not parse SDK version from '%s version' output: %s" % (go_binary_path, result.stdout))
return version

def _parse_versions_json(data):
Expand Down

0 comments on commit bc8512c

Please sign in to comment.