Browse Source
Bazel is still supported in addition to the Bazel wrapper Bazelisk, that is recommended, as it would automatically switch to the right Bazel version on stable branches (like it was the case with Buck). That why minimum used Bazel version check is still needed in WORKSPACE file in addition to the .bazelversion used by Bazelisk. That means that currently, bazel version is maintained in two places: * .bazelversion * WORKSPACE This change introduces the repository rule to read the bazel version from the .bazelversion file and perform the minimum version check. Change-Id: Ib9c1382935ded7bcd322ed0122838c40ba2faa6c Signed-off-by: David Ostrovsky <david@ostrovsky.org>next
David Ostrovsky
5 years ago
2 changed files with 23 additions and 2 deletions
@ -0,0 +1,16 @@ |
|||||||
|
_template = """ |
||||||
|
load("@bazel_skylib//lib:versions.bzl", "versions") |
||||||
|
|
||||||
|
def check_bazel_version(): |
||||||
|
versions.check(minimum_bazel_version = "{version}") |
||||||
|
""".strip() |
||||||
|
|
||||||
|
def _impl(repository_ctx): |
||||||
|
repository_ctx.symlink(Label("@//:.bazelversion"), ".bazelversion") |
||||||
|
bazelversion = repository_ctx.read(".bazelversion").strip() |
||||||
|
|
||||||
|
repository_ctx.file("BUILD", executable = False) |
||||||
|
|
||||||
|
repository_ctx.file("check.bzl", executable = False, content = _template.format(version = bazelversion)) |
||||||
|
|
||||||
|
bazelisk_version = repository_rule(implementation = _impl) |
Loading…
Reference in new issue