From 86d095af4be58fc0314a2d4b27dc59fb91e0aeeb Mon Sep 17 00:00:00 2001
From: Nicholas Junge
+ For example, compiled Windows .res files can be provided here to be embedded in + the binary target. +
+ */ + .add( + attr("additional_linker_inputs", LABEL_LIST) + .orderIndependent() + .direct_compile_time_input() + .allowedFileTypes(FileTypeSet.ANY_FILE)) /* Remove matching options from the C++ compilation command. Subject to "Make" variable substitution. @@ -496,18 +508,6 @@ public CcBinaryBaseRule(GraphNodeAspect graphNodeAspect) { @Override public RuleClass build(RuleClass.Builder builder, RuleDefinitionEnvironment env) { return builder - /* - Pass these files to the C++ linker command. -- For example, compiled Windows .res files can be provided here to be embedded in - the binary target. -
- */ - .add( - attr("additional_linker_inputs", LABEL_LIST) - .orderIndependent() - .direct_compile_time_input() - .allowedFileTypes(FileTypeSet.ANY_FILE)) .override( attr("deps", LABEL_LIST) .allowedRuleClasses(DEPS_ALLOWED_RULES) diff --git a/src/main/starlark/builtins_bzl/common/cc/cc_library.bzl b/src/main/starlark/builtins_bzl/common/cc/cc_library.bzl index 45ad0c8925d36f..d82642cd9cf3e0 100755 --- a/src/main/starlark/builtins_bzl/common/cc/cc_library.bzl +++ b/src/main/starlark/builtins_bzl/common/cc/cc_library.bzl @@ -151,7 +151,7 @@ def _cc_library_impl(ctx): compilation_outputs = compilation_outputs, cc_toolchain = cc_toolchain, feature_configuration = feature_configuration, - additional_inputs = _filter_linker_scripts(ctx.files.deps), + additional_inputs = _filter_linker_scripts(ctx.files.deps) + ctx.files.additional_linker_inputs, linking_contexts = linking_contexts, grep_includes = ctx.executable._grep_includes, user_link_flags = common.linkopts, @@ -209,11 +209,12 @@ def _cc_library_impl(ctx): else: user_link_flags = common.linkopts linker_scripts = _filter_linker_scripts(ctx.files.deps) - if len(common.linkopts) > 0 or len(linker_scripts) > 0 or not semantics.should_create_empty_archive(): + additional_linker_inputs = ctx.files.additional_linker_inputs + if len(user_link_flags) > 0 or len(linker_scripts) > 0 or len(additional_linker_inputs) > 0 or not semantics.should_create_empty_archive(): linker_input = cc_common.create_linker_input( owner = ctx.label, user_link_flags = common.linkopts, - additional_inputs = depset(linker_scripts), + additional_inputs = depset(linker_scripts + additional_linker_inputs), ) contexts_to_merge.append(cc_common.create_linking_context(linker_inputs = depset([linker_input]))) @@ -583,6 +584,10 @@ attrs = { "linkstamp": attr.label(allow_single_file = True), "linkopts": attr.string_list(), "nocopts": attr.string(), + "additional_linker_inputs": attr.label_list( + allow_files = True, + flags = ["ORDER_INDEPENDENT", "DIRECT_COMPILE_TIME_INPUT"], + ), "includes": attr.string_list(), "defines": attr.string_list(), "copts": attr.string_list(),