From 6d544d097bd4b1d60fc7f43928cbfc6c9748809b Mon Sep 17 00:00:00 2001 From: Claudio Bley Date: Fri, 29 Nov 2024 08:42:38 +0100 Subject: [PATCH 1/4] Use `get_cpu_value` from rules_nixpkgs_core in other modules Make the definition private. --- core/private/get_cpu_value.bzl | 39 +++++++++++++++++++++++++++++++++ core/util.bzl | 40 +--------------------------------- nixpkgs/nixpkgs.bzl | 2 +- toolchains/cc/cc.bzl | 5 ++++- toolchains/java/java.bzl | 2 +- toolchains/posix/posix.bzl | 2 +- 6 files changed, 47 insertions(+), 43 deletions(-) create mode 100644 core/private/get_cpu_value.bzl diff --git a/core/private/get_cpu_value.bzl b/core/private/get_cpu_value.bzl new file mode 100644 index 00000000..49b840ea --- /dev/null +++ b/core/private/get_cpu_value.bzl @@ -0,0 +1,39 @@ + +# see https://github.com/tweag/rules_nixpkgs/pull/613 +# taken from https://github.com/bazelbuild/rules_cc/blob/8395ec0172270f3bf92cd7b06c9b5b3f1f679e88/cc/private/toolchain/lib_cc_configure.bzl#L225 +def get_cpu_value(repository_ctx): + """Compute the cpu_value based on the OS name. Doesn't %-escape the result! + + Args: + repository_ctx: The repository context. + Returns: + One of (darwin, freebsd, x64_windows, ppc, s390x, arm, aarch64, k8, piii) + """ + os_name = repository_ctx.os.name + arch = repository_ctx.os.arch + if os_name.startswith("mac os"): + # Check if we are on x86_64 or arm64 and return the corresponding cpu value. + return "darwin_" + ("arm64" if arch == "aarch64" else "x86_64") + if os_name.find("freebsd") != -1: + return "freebsd" + if os_name.find("openbsd") != -1: + return "openbsd" + if os_name.find("windows") != -1: + if arch == "aarch64": + return "arm64_windows" + else: + return "x64_windows" + + if arch in ["power", "ppc64le", "ppc", "ppc64"]: + return "ppc" + if arch in ["s390x"]: + return "s390x" + if arch in ["mips64"]: + return "mips64" + if arch in ["riscv64"]: + return "riscv64" + if arch in ["arm", "armv7l"]: + return "arm" + if arch in ["aarch64"]: + return "aarch64" + return "k8" if arch in ["amd64", "x86_64", "x64"] else "piii" diff --git a/core/util.bzl b/core/util.bzl index b7940627..e9103d6f 100644 --- a/core/util.bzl +++ b/core/util.bzl @@ -1,44 +1,6 @@ load("@bazel_skylib//lib:paths.bzl", "paths") load("@bazel_skylib//lib:versions.bzl", "versions") - -# see https://github.com/tweag/rules_nixpkgs/pull/613 -# taken from https://github.com/bazelbuild/rules_cc/blob/8395ec0172270f3bf92cd7b06c9b5b3f1f679e88/cc/private/toolchain/lib_cc_configure.bzl#L225 -def get_cpu_value(repository_ctx): - """Compute the cpu_value based on the OS name. Doesn't %-escape the result! - - Args: - repository_ctx: The repository context. - Returns: - One of (darwin, freebsd, x64_windows, ppc, s390x, arm, aarch64, k8, piii) - """ - os_name = repository_ctx.os.name - arch = repository_ctx.os.arch - if os_name.startswith("mac os"): - # Check if we are on x86_64 or arm64 and return the corresponding cpu value. - return "darwin_" + ("arm64" if arch == "aarch64" else "x86_64") - if os_name.find("freebsd") != -1: - return "freebsd" - if os_name.find("openbsd") != -1: - return "openbsd" - if os_name.find("windows") != -1: - if arch == "aarch64": - return "arm64_windows" - else: - return "x64_windows" - - if arch in ["power", "ppc64le", "ppc", "ppc64"]: - return "ppc" - if arch in ["s390x"]: - return "s390x" - if arch in ["mips64"]: - return "mips64" - if arch in ["riscv64"]: - return "riscv64" - if arch in ["arm", "armv7l"]: - return "arm" - if arch in ["aarch64"]: - return "aarch64" - return "k8" if arch in ["amd64", "x86_64", "x64"] else "piii" +load("//:private/get_cpu_value.bzl", "get_cpu_value") def fail_on_err(return_value, prefix = None): """Fail if the given return value indicates an error. diff --git a/nixpkgs/nixpkgs.bzl b/nixpkgs/nixpkgs.bzl index b2f579c3..b928383d 100644 --- a/nixpkgs/nixpkgs.bzl +++ b/nixpkgs/nixpkgs.bzl @@ -115,7 +115,7 @@ nixpkgs_package( load("@bazel_tools//tools/cpp:cc_configure.bzl", "cc_autoconf_impl") load( - "@bazel_tools//tools/cpp:lib_cc_configure.bzl", + "@rules_nixpkgs_core//:private/get_cpu_value.bzl", "get_cpu_value", ) load( diff --git a/toolchains/cc/cc.bzl b/toolchains/cc/cc.bzl index 6391fe44..4181da05 100644 --- a/toolchains/cc/cc.bzl +++ b/toolchains/cc/cc.bzl @@ -23,8 +23,11 @@ using `nixpkgs_cc_configure(..., cc_lang = "cuda")` or similar. load("@bazel_skylib//lib:sets.bzl", "sets") load("@bazel_tools//tools/build_defs/repo:utils.bzl", "maybe") load( - "@bazel_tools//tools/cpp:lib_cc_configure.bzl", + "@rules_nixpkgs_core//:private/get_cpu_value.bzl", "get_cpu_value", +) +load( + "@bazel_tools//tools/cpp:lib_cc_configure.bzl", "get_starlark_list", "write_builtin_include_directory_paths", ) diff --git a/toolchains/java/java.bzl b/toolchains/java/java.bzl index 6d3c43b4..fb229dd8 100644 --- a/toolchains/java/java.bzl +++ b/toolchains/java/java.bzl @@ -8,7 +8,7 @@ """ load( - "@bazel_tools//tools/cpp:lib_cc_configure.bzl", + "@rules_nixpkgs_core//:private/get_cpu_value.bzl", "get_cpu_value", ) load( diff --git a/toolchains/posix/posix.bzl b/toolchains/posix/posix.bzl index 50b50f59..a0c04470 100644 --- a/toolchains/posix/posix.bzl +++ b/toolchains/posix/posix.bzl @@ -8,7 +8,7 @@ Rules for importing a POSIX toolchain from Nixpkgs. """ load( - "@bazel_tools//tools/cpp:lib_cc_configure.bzl", + "@rules_nixpkgs_core//:private/get_cpu_value.bzl", "get_cpu_value", ) load("@rules_nixpkgs_core//:nixpkgs.bzl", "nixpkgs_package") From f790356363a5dcb3669905f5c276ca225bf3e355 Mon Sep 17 00:00:00 2001 From: Claudio Bley Date: Fri, 29 Nov 2024 09:30:42 +0100 Subject: [PATCH 2/4] Add local path overrides for rules_nipxkgs_core --- toolchains/go/MODULE.bazel | 4 ++++ toolchains/java/MODULE.bazel | 4 ++++ toolchains/nodejs/MODULE.bazel | 4 ++++ toolchains/posix/MODULE.bazel | 4 ++++ toolchains/python/MODULE.bazel | 4 ++++ toolchains/rust/MODULE.bazel | 4 ++++ 6 files changed, 24 insertions(+) diff --git a/toolchains/go/MODULE.bazel b/toolchains/go/MODULE.bazel index 646cebd1..2f877f64 100644 --- a/toolchains/go/MODULE.bazel +++ b/toolchains/go/MODULE.bazel @@ -4,6 +4,10 @@ module( ) bazel_dep(name = "rules_nixpkgs_core", version = "0.12.0") +local_path_override( + module_name = "rules_nixpkgs_core", + path = "../../core", +) bazel_dep(name = "rules_go", repo_name = "io_bazel_rules_go", version = "0.39.1") bazel_dep(name = "bazel_skylib", version = "1.0.3") bazel_dep(name = "platforms", version = "0.0.4") diff --git a/toolchains/java/MODULE.bazel b/toolchains/java/MODULE.bazel index 5c7a6ed6..393e61ea 100644 --- a/toolchains/java/MODULE.bazel +++ b/toolchains/java/MODULE.bazel @@ -4,6 +4,10 @@ module( ) bazel_dep(name = "rules_nixpkgs_core", version = "0.12.0") +local_path_override( + module_name = "rules_nixpkgs_core", + path = "../../core", +) bazel_dep(name = "rules_java", version = "7.3.1") bazel_dep(name = "bazel_skylib", version = "1.0.3") diff --git a/toolchains/nodejs/MODULE.bazel b/toolchains/nodejs/MODULE.bazel index 9b154e7c..85ef3a3d 100644 --- a/toolchains/nodejs/MODULE.bazel +++ b/toolchains/nodejs/MODULE.bazel @@ -4,6 +4,10 @@ module( ) bazel_dep(name = "rules_nixpkgs_core", version = "0.12.0") +local_path_override( + module_name = "rules_nixpkgs_core", + path = "../../core", +) bazel_dep(name = "platforms", version = "0.0.4") bazel_dep(name = "rules_nodejs", version = "5.5.3") bazel_dep(name = "bazel_skylib", version = "1.0.3") diff --git a/toolchains/posix/MODULE.bazel b/toolchains/posix/MODULE.bazel index 3693ab74..b25c2478 100644 --- a/toolchains/posix/MODULE.bazel +++ b/toolchains/posix/MODULE.bazel @@ -4,5 +4,9 @@ module( ) bazel_dep(name = "rules_nixpkgs_core", version = "0.12.0") +local_path_override( + module_name = "rules_nixpkgs_core", + path = "../../core", +) bazel_dep(name = "rules_sh", version = "0.3.0") bazel_dep(name = "bazel_skylib", version = "1.0.3") diff --git a/toolchains/python/MODULE.bazel b/toolchains/python/MODULE.bazel index a867e1ae..d9ebe436 100644 --- a/toolchains/python/MODULE.bazel +++ b/toolchains/python/MODULE.bazel @@ -4,4 +4,8 @@ module( ) bazel_dep(name = "rules_nixpkgs_core", version = "0.12.0") +local_path_override( + module_name = "rules_nixpkgs_core", + path = "../../core", +) bazel_dep(name = "bazel_skylib", version = "1.0.3") diff --git a/toolchains/rust/MODULE.bazel b/toolchains/rust/MODULE.bazel index b3d35717..cdacfe52 100644 --- a/toolchains/rust/MODULE.bazel +++ b/toolchains/rust/MODULE.bazel @@ -4,5 +4,9 @@ module( ) bazel_dep(name = "rules_nixpkgs_core", version = "0.12.0") +local_path_override( + module_name = "rules_nixpkgs_core", + path = "../../core", +) bazel_dep(name = "bazel_skylib", version = "1.5.0") bazel_dep(name = "rules_rust", version = "0.35.0") From 0a4a9328e2df72b2a2274a0118c7f7abba73ac65 Mon Sep 17 00:00:00 2001 From: Claudio Bley Date: Fri, 29 Nov 2024 10:04:47 +0100 Subject: [PATCH 3/4] Add get_cpu_value.bzl to bzl_library --- core/BUILD.bazel | 1 + 1 file changed, 1 insertion(+) diff --git a/core/BUILD.bazel b/core/BUILD.bazel index 74cb7a80..f19c53c0 100644 --- a/core/BUILD.bazel +++ b/core/BUILD.bazel @@ -26,6 +26,7 @@ bzl_library( srcs = [ "nixpkgs.bzl", "util.bzl", + "private/get_cpu_value.bzl", ], deps = [ ":bazel_tools", From 3d390678719777558365e8d6c92435fafa09cc70 Mon Sep 17 00:00:00 2001 From: Claudio Bley Date: Fri, 29 Nov 2024 10:54:02 +0100 Subject: [PATCH 4/4] Return "darwin" as cpu value on x86_64 for Bazel < 7 --- core/private/get_cpu_value.bzl | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/core/private/get_cpu_value.bzl b/core/private/get_cpu_value.bzl index 49b840ea..f2fcc577 100644 --- a/core/private/get_cpu_value.bzl +++ b/core/private/get_cpu_value.bzl @@ -1,3 +1,4 @@ +load("@bazel_skylib//lib:versions.bzl", "versions") # see https://github.com/tweag/rules_nixpkgs/pull/613 # taken from https://github.com/bazelbuild/rules_cc/blob/8395ec0172270f3bf92cd7b06c9b5b3f1f679e88/cc/private/toolchain/lib_cc_configure.bzl#L225 @@ -13,7 +14,15 @@ def get_cpu_value(repository_ctx): arch = repository_ctx.os.arch if os_name.startswith("mac os"): # Check if we are on x86_64 or arm64 and return the corresponding cpu value. - return "darwin_" + ("arm64" if arch == "aarch64" else "x86_64") + if arch == "aarch64": + return "darwin_arm64" + + # NOTE(cb) for backward compatibility return "darwin" for Bazel < 7 on x86_64 + if versions.is_at_least("7.0.0", versions.get()): + return "darwin_x86_64" + else: + return "darwin" + if os_name.find("freebsd") != -1: return "freebsd" if os_name.find("openbsd") != -1: