diff --git a/MODULE.bazel b/MODULE.bazel index 23d98efe07..0dacee1b11 100644 --- a/MODULE.bazel +++ b/MODULE.bazel @@ -27,7 +27,7 @@ use_repo( register_toolchains("@go_toolchains//:all") -bazel_dep(name = "gazelle", version = "0.34.0") +bazel_dep(name = "gazelle", version = "0.36.0") go_deps = use_extension("@gazelle//:extensions.bzl", "go_deps") go_deps.from_file(go_mod = "//:go.mod") diff --git a/go/modes.rst b/go/modes.rst index 431049d53d..54681d9b56 100644 --- a/go/modes.rst +++ b/go/modes.rst @@ -68,6 +68,8 @@ or using `Bazel configuration transitions`_. | Disables cgo, even when a C/C++ toolchain is configured (similar to setting | | ``CGO_ENABLED=0``). Packages that contain cgo code may still be built, but | | the cgo code will be filtered out, and the ``cgo`` build tag will be false. | +| Sets the de-facto ``purego`` build tag for conditional inclusion of source | +| files. | +-------------------+---------------------+------------------------------------+ | :param:`debug` | :type:`bool` | :value:`false` | +-------------------+---------------------+------------------------------------+ diff --git a/go/private/mode.bzl b/go/private/mode.bzl index 2318fd094c..2babb7f742 100644 --- a/go/private/mode.bzl +++ b/go/private/mode.bzl @@ -122,6 +122,8 @@ def get_mode(ctx, go_toolchain, cgo_context_info, go_config_info): tags.append("race") if msan: tags.append("msan") + if pure: + tags.append("purego") return struct( static = static, diff --git a/tests/core/cgo/BUILD.bazel b/tests/core/cgo/BUILD.bazel index 3fcd9875ef..16bae440b5 100644 --- a/tests/core/cgo/BUILD.bazel +++ b/tests/core/cgo/BUILD.bazel @@ -334,6 +334,7 @@ go_test( data = [ ":tag_cgo_bin", ":tag_pure_bin", + ":tag_purego_bin", ], rundir = ".", deps = ["//go/tools/bazel:go_default_library"], @@ -350,6 +351,17 @@ go_binary( pure = "on", ) +go_binary( + name = "tag_purego_bin", + srcs = [ + "tag_purego.go", + "tag_purego_err.c", + "tag_purego_err.go", + ], + cgo = True, + pure = "on", +) + go_binary( name = "tag_cgo_bin", srcs = [ diff --git a/tests/core/cgo/tag_purego.go b/tests/core/cgo/tag_purego.go new file mode 100644 index 0000000000..31d2375fac --- /dev/null +++ b/tests/core/cgo/tag_purego.go @@ -0,0 +1,9 @@ +// +build purego + +package main + +import "fmt" + +func main() { + fmt.Println("purego") +} diff --git a/tests/core/cgo/tag_purego_err.c b/tests/core/cgo/tag_purego_err.c new file mode 100644 index 0000000000..c92fa97ca8 --- /dev/null +++ b/tests/core/cgo/tag_purego_err.c @@ -0,0 +1 @@ +#error should not be compiled diff --git a/tests/core/cgo/tag_purego_err.go b/tests/core/cgo/tag_purego_err.go new file mode 100644 index 0000000000..059c2bafbd --- /dev/null +++ b/tests/core/cgo/tag_purego_err.go @@ -0,0 +1,6 @@ +// +build !purego + +package main + +// this file should not be compiled +!!! diff --git a/tests/core/cgo/tag_test.go b/tests/core/cgo/tag_test.go index b1ad4c9906..1e62747761 100644 --- a/tests/core/cgo/tag_test.go +++ b/tests/core/cgo/tag_test.go @@ -15,6 +15,9 @@ func Test(t *testing.T) { { name: "tag_pure_bin", want: "pure", + }, { + name: "tag_purego_bin", + want: "purego", }, { name: "tag_cgo_bin", want: "cgo",