From 8760a91775c88a58e58fe4e19e775d1e0d1ab234 Mon Sep 17 00:00:00 2001 From: Googler Date: Tue, 11 Oct 2022 08:16:33 -0700 Subject: [PATCH] Automated rollback of commit 21904a92b800139499f2f62c7c4c11351fa8bc0c. *** Reason for rollback *** Due to https://github.com/bazelbuild/bazel/issues/16296#issuecomment-1273507703 *** Original change description *** Collect implementation_deps in graph node aspect This is needed for implementation_deps of cc_library targets to be linked into cc_binary targets with dynamic_deps and cc_shared_library targets. Fixes #14731 Closes #14730. PiperOrigin-RevId: 480360695 Change-Id: Ic1b9c17ce3af730fa0131f5d87e5ca99ae2740c5 --- .../build/lib/rules/cpp/GraphNodeAspect.java | 11 +++-------- .../test_cc_shared_library/BUILD.builtin_test | 8 -------- .../cc_shared_library_integration_test.sh | 1 - .../test_cc_shared_library/foo.cc | 2 -- .../implementation_dep.cc | 16 ---------------- .../implementation_dep.h | 19 ------------------- .../tests/builtins_bzl/cc_builtin_tests.sh | 3 +-- 7 files changed, 4 insertions(+), 56 deletions(-) delete mode 100644 src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/implementation_dep.cc delete mode 100644 src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/implementation_dep.h diff --git a/src/main/java/com/google/devtools/build/lib/rules/cpp/GraphNodeAspect.java b/src/main/java/com/google/devtools/build/lib/rules/cpp/GraphNodeAspect.java index 8b906e42bbd313..0f333392b6b373 100644 --- a/src/main/java/com/google/devtools/build/lib/rules/cpp/GraphNodeAspect.java +++ b/src/main/java/com/google/devtools/build/lib/rules/cpp/GraphNodeAspect.java @@ -50,8 +50,6 @@ public AspectParameters apply(Rule rule) { : null; } }; - private static final ImmutableList CC_DEPS_ATTRIBUTES = - ImmutableList.of("deps", "implementation_deps"); @Override public AspectDefinition getDefinition(AspectParameters aspectParameters) { @@ -69,12 +67,9 @@ public ConfiguredAspect create( RepositoryName toolsRepository) throws ActionConflictException, InterruptedException { ImmutableList.Builder children = ImmutableList.builder(); - for (String depsAttribute : CC_DEPS_ATTRIBUTES) { - if (ruleContext.attributes().has(depsAttribute)) { - children.addAll( - AnalysisUtils.getProviders( - ruleContext.getPrerequisites(depsAttribute), GraphNodeInfo.class)); - } + if (ruleContext.attributes().has("deps")) { + children.addAll( + AnalysisUtils.getProviders(ruleContext.getPrerequisites("deps"), GraphNodeInfo.class)); } return new ConfiguredAspect.Builder(ruleContext) .addProvider( diff --git a/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/BUILD.builtin_test b/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/BUILD.builtin_test index 025a08f2dd26ec..39dcd2053cbfd7 100644 --- a/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/BUILD.builtin_test +++ b/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/BUILD.builtin_test @@ -90,7 +90,6 @@ cc_shared_library( "a_suffix", ], static_deps = [ - "//src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library:implementation_dep", "//src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library:qux", "//src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library:qux2", "//src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library:prebuilt", @@ -111,12 +110,6 @@ cc_library( hdrs = ["preloaded_dep.h"], ) -cc_library( - name = "implementation_dep", - srcs = ["implementation_dep.cc"], - hdrs = ["implementation_dep.h"], -) - cc_library( name = "foo", srcs = [ @@ -131,7 +124,6 @@ cc_library( "//src/conditions:linux": ["IS_LINUX"], "//conditions:default": [], }), - implementation_deps = ["implementation_dep"], deps = [ "preloaded_dep", "bar", diff --git a/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/cc_shared_library_integration_test.sh b/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/cc_shared_library_integration_test.sh index cc62155f972501..a6b480bff2d95d 100755 --- a/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/cc_shared_library_integration_test.sh +++ b/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/cc_shared_library_integration_test.sh @@ -48,7 +48,6 @@ function test_shared_library_symbols() { check_symbol_absent "$symbols" "_Z3quxv" check_symbol_absent "$symbols" "_Z4bar3v" check_symbol_absent "$symbols" "_Z4bar4v" - check_symbol_absent "$symbols" "_Z18implementation_depv" } function test_shared_library_user_link_flags() { diff --git a/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/foo.cc b/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/foo.cc index c87ca093e33023..cc9c8da410e740 100644 --- a/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/foo.cc +++ b/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/foo.cc @@ -15,14 +15,12 @@ #include "src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/baz.h" #include "src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/direct_so_file_cc_lib.h" #include "src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/direct_so_file_cc_lib2.h" -#include "src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/implementation_dep.h" #include "src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/preloaded_dep.h" #include "src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/qux.h" int foo() { bar(); baz(); - implementation_dep(); qux(); #ifdef IS_LINUX direct_so_file_cc_lib(); diff --git a/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/implementation_dep.cc b/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/implementation_dep.cc deleted file mode 100644 index 4297573f2fcfdb..00000000000000 --- a/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/implementation_dep.cc +++ /dev/null @@ -1,16 +0,0 @@ -// Copyright 2016 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 "src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/implementation_dep.h" - -int implementation_dep() { return 43; } diff --git a/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/implementation_dep.h b/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/implementation_dep.h deleted file mode 100644 index 2ca3acf740b0f6..00000000000000 --- a/src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/implementation_dep.h +++ /dev/null @@ -1,19 +0,0 @@ -// Copyright 2016 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. -#ifndef EXAMPLES_TEST_CC_SHARED_LIBRARY_IMPLEMENTATION_DEP_H_ -#define EXAMPLES_TEST_CC_SHARED_LIBRARY_IMPLEMENTATION_DEP_H_ - -int implementation_dep(); - -#endif // EXAMPLES_TEST_CC_SHARED_LIBRARY_IMPLEMENTATION_DEP_H_ diff --git a/src/main/starlark/tests/builtins_bzl/cc_builtin_tests.sh b/src/main/starlark/tests/builtins_bzl/cc_builtin_tests.sh index d72467296f42c9..005d6792899833 100755 --- a/src/main/starlark/tests/builtins_bzl/cc_builtin_tests.sh +++ b/src/main/starlark/tests/builtins_bzl/cc_builtin_tests.sh @@ -73,8 +73,7 @@ EOF --experimental_link_static_libraries_once \ --experimental_enable_target_export_check --experimental_cc_shared_library \ --experimental_builtins_injection_override=+cc_binary \ - --experimental_cc_implementation_deps \ //src/main/starlark/tests/builtins_bzl/cc/... || fail "expected success" } -run_suite "cc_* built starlark test" +run_suite "cc_* built starlark test" \ No newline at end of file