Skip to content

Commit

Permalink
Add well-known compiler config_settings
Browse files Browse the repository at this point in the history
As of Bazel 6.0.0, all Bazel-provided toolchains report consistent
compiler names that can be matched on with `select`. Having a central
place for `config_setting`s that can be used for this purpose makes it
so that rulesets don't have to define them themselves and moving the
compiler flag out of `@bazel_tools` becomes easier as it is no longer
referenced directly.

Also includes minor fixes to `//tests/...` so that it can be enabled in
CI.
  • Loading branch information
fmeum committed Jul 6, 2023
1 parent 1dbb691 commit 0399dbb
Show file tree
Hide file tree
Showing 5 changed files with 132 additions and 0 deletions.
2 changes: 2 additions & 0 deletions .bazelci/presubmit.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ x_defaults:
- "//examples/my_c_compile:all"
- "//examples/write_cc_toolchain_cpu:all"
- "//tools/migration:all"
- "//tests/..."
test_flags:
- "--test_timeout=120"
test_targets:
Expand All @@ -29,6 +30,7 @@ x_defaults:
- "//examples/my_c_compile:all"
- "//examples/write_cc_toolchain_cpu:all"
- "//tools/migration:all"
- "//tests/..."

buildifier:
version: latest
Expand Down
73 changes: 73 additions & 0 deletions cc/compiler/BUILD
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
# Copyright 2023 The Bazel Authors. All rights reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

"""Config settings for compilers identified by Bazel.
Targets that require compiler-specific flags can use the config_settings defined
in this package in their select() statements.
*Note*: Before Bazel 6, gcc on Linux and clang on macOS would not match their
specific config_setting, but only the fallback case of a select expression.
Toolchains not shipped with Bazel are encouraged to use the same names to
identify compilers as used below, but this is not enforced.
Example:
cc_binary(
name = "foo",
srcs = ["foo.cc"],
copts = select({
"@rules_cc//cc/compiler:gcc": [...],
"@rules_cc//cc/compiler:clang": [...],
"@rules_cc//cc/compiler:msvc-cl": [...],
# Fallback case for an undetected compiler.
"//conditions:default": [...],
}),
)
If multiple targets use the same set of conditionally enabled flags, this can be
simplified by extracting the select expression into a Starlark constant.
"""

package(default_visibility = ["//visibility:public"])

licenses(["notice"]) # Apache 2.0

_COMPILER_FLAG = "@bazel_tools//tools/cpp:compiler"

config_setting(
name = "clang",
flag_values = {_COMPILER_FLAG: "clang"},
)

config_setting(
name = "clang-cl",
flag_values = {_COMPILER_FLAG: "clang-cl"},
)

config_setting(
name = "gcc",
flag_values = {_COMPILER_FLAG: "gcc"},
)

config_setting(
name = "mingw-gcc",
flag_values = {_COMPILER_FLAG: "mingw-gcc"},
)

config_setting(
name = "msvc-cl",
flag_values = {_COMPILER_FLAG: "msvc-cl"},
)
32 changes: 32 additions & 0 deletions tests/compiler_settings/BUILD
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
# Copyright 2023 The Bazel Authors. All rights reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

load("//cc:defs.bzl", "cc_binary")

licenses(["notice"])

cc_binary(
name = "main",
srcs = ["main.cc"],
local_defines = select(
{
"//cc/compiler:clang": ["COMPILER=clang"],
"//cc/compiler:clang-cl": ["COMPILER=clang-cl"],
"//cc/compiler:gcc": ["COMPILER=gcc"],
"//cc/compiler:mingw-gcc": ["COMPILER=mingw-gcc"],
"//cc/compiler:msvc-cl": ["COMPILER=msvc-cl"],
},
no_match_error = "Compiler not detected by Bazel",
),
)
22 changes: 22 additions & 0 deletions tests/compiler_settings/main.cc
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
// Copyright 2023 The Bazel Authors. All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#include <iostream>

#define STRINGIFY(x) #x
#define TO_STRING(x) STRINGIFY(x)

int main() {
std::cout << "Hello, " << TO_STRING(COMPILER) << "!" << std::endl;
}
3 changes: 3 additions & 0 deletions tests/system_library/BUILD
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,7 @@ sh_test(
"//cc:system_library.bzl",
"@bazel_tools//tools/bash/runfiles",
],
target_compatible_with = [
"@platforms//os:linux",
],
)

0 comments on commit 0399dbb

Please sign in to comment.