# Copyright 2024 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. """Implementation of the cc_toolchain rule.""" load( "//cc/toolchains:cc_toolchain_info.bzl", "ActionTypeSetInfo", "ArgsListInfo", "FeatureSetInfo", "ToolConfigInfo", "ToolchainConfigInfo", ) load(":collect.bzl", "collect_action_types") load(":legacy_converter.bzl", "convert_toolchain") load(":toolchain_config_info.bzl", "toolchain_config_info") visibility([ "//cc/toolchains/...", "//tests/rule_based_toolchain/...", ]) def _cc_legacy_file_group_impl(ctx): files = ctx.attr.config[ToolchainConfigInfo].files return [DefaultInfo(files = depset(transitive = [ files[action] for action in collect_action_types(ctx.attr.actions).to_list() if action in files ]))] cc_legacy_file_group = rule( implementation = _cc_legacy_file_group_impl, attrs = { "actions": attr.label_list(providers = [ActionTypeSetInfo], mandatory = True), "config": attr.label(providers = [ToolchainConfigInfo], mandatory = True), }, ) def _cc_toolchain_config_impl(ctx): if ctx.attr.features: fail("Features is a reserved attribute in bazel. Did you mean 'known_features' or 'enabled_features'?") toolchain_config = toolchain_config_info( label = ctx.label, known_features = ctx.attr.known_features + [ctx.attr._builtin_features], enabled_features = ctx.attr.enabled_features, tool_map = ctx.attr.tool_map, args = ctx.attr.args, ) legacy = convert_toolchain(toolchain_config) return [ toolchain_config, cc_common.create_cc_toolchain_config_info( ctx = ctx, action_configs = legacy.action_configs, features = legacy.features, cxx_builtin_include_directories = legacy.cxx_builtin_include_directories, # toolchain_identifier is deprecated, but setting it to None results # in an error that it expected a string, and for safety's sake, I'd # prefer to provide something unique. toolchain_identifier = str(ctx.label), # These fields are only relevant for legacy toolchain resolution. target_system_name = "", target_cpu = "", target_libc = "", compiler = "", abi_version = "", abi_libc_version = "", ), # This allows us to support all_files. # If all_files was simply an alias to # //cc/toolchains/actions:all_actions, # then if a toolchain introduced a new type of action, it wouldn't get # put in all_files. DefaultInfo(files = depset(transitive = toolchain_config.files.values())), ] cc_toolchain_config = rule( implementation = _cc_toolchain_config_impl, # @unsorted-dict-items attrs = { # Attributes new to this rule. "tool_map": attr.label(providers = [ToolConfigInfo], mandatory = True), "args": attr.label_list(providers = [ArgsListInfo]), "known_features": attr.label_list(providers = [FeatureSetInfo]), "enabled_features": attr.label_list(providers = [FeatureSetInfo]), "_builtin_features": attr.label(default = "//cc/toolchains/features:all_builtin_features"), }, provides = [ToolchainConfigInfo], )