From 0986ab64295a5b327ee6ccddccf65020dbc8e8cb Mon Sep 17 00:00:00 2001 From: Stefan Penner Date: Wed, 6 Dec 2023 16:19:36 +0000 Subject: [PATCH] Use prebuilt shellcheck binaries from https://github.com/vscode-shellcheck/shellcheck-binaries This adds support for the following architectures: * darwin_aarch64 (apple silicon) * linux_armv6hf (raspberry pi) * windows_x86_64 --- BUILD.bazel | 34 ++++++++++++++++++++++++++++++++++ MODULE.bazel | 3 +++ deps.bzl | 23 +++++++++++++---------- 3 files changed, 50 insertions(+), 10 deletions(-) diff --git a/BUILD.bazel b/BUILD.bazel index 5cbf540..fffcef0 100644 --- a/BUILD.bazel +++ b/BUILD.bazel @@ -18,6 +18,21 @@ alias( visibility = ["//:__subpackages__"], ) +constraint_setting(name = "cpu") +constraint_value( + name = "armv6hf", + constraint_setting = ":cpu", +) + +# rasberry pi +config_setting( + name = "linux_armv6hf", + constraint_values = [ + "@platforms//os:linux", + "//:armv6hf", + ] +) + config_setting( name = "darwin_x86_64", constraint_values = [ @@ -26,6 +41,14 @@ config_setting( ], ) +config_setting( + name = "darwin_aarch64", + constraint_values = [ + "@platforms//os:macos", + "@platforms//cpu:aarch64", + ], +) + config_setting( name = "linux_x86_64", constraint_values = [ @@ -42,13 +65,24 @@ config_setting( ], ) +config_setting( + name = "windows_x86_64", + constraint_values = [ + "@platforms//os:windows", + "@platforms//cpu:x86_64", + ], +) + alias( name = "shellcheck", actual = select( { + ":darwin_aarch64": "@shellcheck_darwin_aarch64//:shellcheck", ":darwin_x86_64": "@shellcheck_darwin_amd64//:shellcheck", ":linux_aarch64": "@shellcheck_linux_arm64//:shellcheck", + ":linux_armv6hf": "@shellcheck_linux_armv6hf//:shellcheck", ":linux_x86_64": "@shellcheck_linux_amd64//:shellcheck", + ":windows_x86_64": "@shellcheck_windows_x86_64//:shellcheck", }, no_match_error = "binaries for your platform could not be found", ), diff --git a/MODULE.bazel b/MODULE.bazel index 31c50ce..1f72103 100644 --- a/MODULE.bazel +++ b/MODULE.bazel @@ -9,9 +9,12 @@ bazel_dep(name = "platforms", version = "0.0.7") deps = use_extension("//internal:extensions.bzl", "shellcheck_dependencies") use_repo( deps, + "shellcheck_darwin_aarch64", "shellcheck_darwin_amd64", "shellcheck_linux_amd64", "shellcheck_linux_arm64", + "shellcheck_linux_armv6hf", + "shellcheck_windows_x86_64", ) bazel_dep(name = "rules_pkg", version = "0.9.1", dev_dependency = True) diff --git a/deps.bzl b/deps.bzl index 680420c..87ea6b1 100644 --- a/deps.bzl +++ b/deps.bzl @@ -7,16 +7,17 @@ load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive") load("@bazel_tools//tools/build_defs/repo:utils.bzl", "maybe") _LABELS = { - "darwin_amd64": "darwin.x86_64", - "linux_amd64": "linux.x86_64", - "linux_arm64": "linux.aarch64", - # darwin_arm64 shellcheck binaries are not distributed from GitHub releases. - # windows_amd64 shellcheck binaries are not distributed from GitHub releases. + "darwin_aarch64": "darwin.aarch64", + "darwin_amd64": "darwin.x86_64", + "linux_amd64": "linux.x86_64", + "linux_arm64": "linux.aarch64", + "linux_armv6hf": "linux.armv6hf", + "windows_x86_64": "windows.x86_64", } def _urls(arch, version): return [ - "https://github.com/koalaman/shellcheck/releases/download/{version}/shellcheck-{version}.{arch}.tar.xz".format( + "https://github.com/vscode-shellcheck/shellcheck-binaries/releases/download/{version}/shellcheck-{version}.{arch}.tar.gz".format( version = version, arch = _LABELS[arch], ), @@ -25,9 +26,12 @@ def _urls(arch, version): def shellcheck_dependencies(): version = "v0.9.0" sha256 = { - "darwin_amd64": "7d3730694707605d6e60cec4efcb79a0632d61babc035aa16cda1b897536acf5", - "linux_amd64": "700324c6dd0ebea0117591c6cc9d7350d9c7c5c287acbad7630fa17b1d4d9e2f", - "linux_arm64": "179c579ef3481317d130adebede74a34dbbc2df961a70916dd4039ebf0735fae", + "darwin_aarch64": "a75b912015aaa5b2a48698b63f3619783d90abda4d32a31362209315e6c1cdf6", + "darwin_amd64": "d1244da2aa5d0c2874f3a4a680c6ac79a488ff6dbf9928e12dc80ff3fdc294db", + "linux_amd64": "0ab5711861e6fcafad5aa21587ee75bbd2b16505d56f41c9ba1191a83d314074", + "linux_arm64": "b5633bd195cfe61a310bd8dcff2514855afefea908942a0fd4d01fa6451cb4e6", + "linux_armv6hf": "4791d36d84a626c4366746d14ad68daf2c07f502da09319c45fa6c5c0a847aa9", + "windows_x86_64": "a0f021057b6d6a69a22f6b0db0187bcaca3f5195385e92a7555ad63a6e39ee15", } for arch, sha256 in sha256.items(): @@ -36,7 +40,6 @@ def shellcheck_dependencies(): name = "shellcheck_{arch}".format(arch = arch), build_file_content = """exports_files(["shellcheck"]) """, - strip_prefix = "shellcheck-{version}".format(version = version), sha256 = sha256, urls = _urls(arch = arch, version = version), )