Skip to content

Commit

Permalink
Collect implementation_deps in graph node aspect
Browse files Browse the repository at this point in the history
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.
  • Loading branch information
fmeum committed Feb 4, 2022
1 parent 5c4422e commit 1809779
Show file tree
Hide file tree
Showing 8 changed files with 66 additions and 8 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
import com.google.devtools.build.lib.packages.NativeAspectClass;
import com.google.devtools.build.lib.packages.Rule;
import com.google.devtools.build.lib.skyframe.ConfiguredTargetAndData;
import java.util.List;
import javax.annotation.Nullable;

/**
Expand All @@ -50,6 +51,8 @@ public AspectParameters apply(Rule rule) {
: null;
}
};
private static final List<String> CC_DEPS_ATTRIBUTES = ImmutableList.of("deps",
"implementation_deps");

@Override
public AspectDefinition getDefinition(AspectParameters aspectParameters) {
Expand All @@ -67,9 +70,12 @@ public ConfiguredAspect create(
RepositoryName toolsRepository)
throws ActionConflictException, InterruptedException {
ImmutableList.Builder<GraphNodeInfo> children = ImmutableList.builder();
if (ruleContext.attributes().has("deps")) {
children.addAll(
AnalysisUtils.getProviders(ruleContext.getPrerequisites("deps"), GraphNodeInfo.class));
for (String depsAttribute : CC_DEPS_ATTRIBUTES) {
if (ruleContext.attributes().has(depsAttribute)) {
children.addAll(
AnalysisUtils.getProviders(ruleContext.getPrerequisites(depsAttribute),
GraphNodeInfo.class));
}
}
return new ConfiguredAspect.Builder(ruleContext)
.addProvider(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -517,14 +517,19 @@ def _cc_shared_library_impl(ctx):
),
]

_CC_DEPS_ATTRIBUTES = ["deps", "implementation_deps"]

def _graph_structure_aspect_impl(target, ctx):
children = []

# For now ignore cases when deps is of type label instead of label_list.
if hasattr(ctx.rule.attr, "deps") and type(ctx.rule.attr.deps) != "Target":
for dep in ctx.rule.attr.deps:
if GraphNodeInfo in dep:
children.append(dep[GraphNodeInfo])
for deps_attr in _CC_DEPS_ATTRIBUTES:
deps = getattr(ctx.rule.attr, deps_attr, None)

# For now ignore cases when deps is of type label instead of label_list.
if deps and type(deps) != "Target":
for dep in deps:
if GraphNodeInfo in dep:
children.append(dep[GraphNodeInfo])

# TODO(bazel-team): Add flag to Bazel that can toggle the initialization of
# linkable_more_than_once.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,7 @@ 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",
Expand All @@ -98,6 +99,12 @@ cc_library(
hdrs = ["preloaded_dep.h"],
)

cc_library(
name = "implementation_dep",
srcs = ["implementation_dep.cc"],
hdrs = ["implementation_dep.h"],
)

cc_library(
name = "foo",
srcs = ["foo.cc"],
Expand All @@ -106,6 +113,7 @@ cc_library(
"//src/conditions:linux": ["IS_LINUX"],
"//conditions:default": [],
}),
implementation_deps = ["implementation_dep"],
deps = [
"preloaded_dep",
"bar",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@ 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() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,12 +13,14 @@
// limitations under the License.
#include "src/main/starlark/tests/builtins_bzl/cc/cc_shared_library/test_cc_shared_library/bar.h"
#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/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
preloaded_dep();
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
// 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; }
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
// 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_
1 change: 1 addition & 0 deletions src/main/starlark/tests/builtins_bzl/cc_builtin_tests.sh
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,7 @@ EOF
--experimental_cc_shared_library_debug \
--experimental_link_static_libraries_once \
--experimental_enable_target_export_check --experimental_cc_shared_library \
--experimental_cc_implementation_deps \
//src/main/starlark/tests/builtins_bzl/cc/... || fail "expected success"
}

Expand Down

0 comments on commit 1809779

Please sign in to comment.