Skip to content

Commit

Permalink
Collect debug info context from implementation deps
Browse files Browse the repository at this point in the history
  • Loading branch information
thii committed Oct 4, 2023
1 parent 33b61e1 commit 1442f96
Show file tree
Hide file tree
Showing 2 changed files with 56 additions and 1 deletion.
5 changes: 4 additions & 1 deletion src/main/starlark/builtins_bzl/common/cc/cc_library.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -304,7 +304,10 @@ def _cc_library_impl(ctx):
data_runfiles = data_runfiles,
))

debug_context = cc_helper.merge_cc_debug_contexts(compilation_outputs, cc_helper.get_providers(ctx.attr.deps, CcInfo))
debug_context = cc_helper.merge_cc_debug_contexts(
compilation_outputs,
cc_helper.get_providers(ctx.attr.deps + ctx.attr.implementation_deps, CcInfo),
)
cc_info = CcInfo(
compilation_context = compilation_context,
linking_context = linking_context,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2000,6 +2000,58 @@ public void testImplementationDepsLinkingContextIsPropagated() throws Exception
.contains("bin foo/libimplementation_dep.a");
}

@Test
public void testImplementationDepsDebugContextIsPropagated() throws Exception {
useConfiguration("--experimental_cc_implementation_deps");
scratch.file(
"foo/BUILD",
"cc_binary(",
" name = 'bin',",
" srcs = ['bin.cc'],",
" deps = ['lib'],",
")",
"cc_library(",
" name = 'lib',",
" srcs = ['lib.cc'],",
" deps = ['public_dep'],",
")",
"cc_library(",
" name = 'public_dep',",
" srcs = ['public_dep.cc'],",
" hdrs = ['public_dep.h'],",
" implementation_deps = ['implementation_dep'],",
" deps = ['interface_dep'],",
")",
"cc_library(",
" name = 'interface_dep',",
" srcs = ['interface_dep.cc'],",
" hdrs = ['interface_dep.h'],",
")",
"cc_library(",
" name = 'implementation_dep',",
" srcs = ['implementation_dep.cc'],",
" hdrs = ['implementation_dep.h'],",
")");

ConfiguredTarget lib = getConfiguredTarget("//foo:lib");
assertThat(
lib.get(CcInfo.PROVIDER)
.getCcDebugInfoContext()
.getTransitiveDwoFiles()
.toList()
.stream()
.map(Artifact::getFilename))
.contains("public_dep.dwo");
assertThat(
lib.get(CcInfo.PROVIDER)
.getCcDebugInfoContext()
.getTransitiveDwoFiles()
.toList()
.stream()
.map(Artifact::getFilename))
.contains("implementation_dep.dwo");
}

@Test
public void testImplementationDepsRunfilesArePropagated() throws Exception {
useConfiguration("--experimental_cc_implementation_deps");
Expand Down

0 comments on commit 1442f96

Please sign in to comment.