Skip to content

Commit

Permalink
[6.4.0] Collect debug info context from implementation deps (#19836)
Browse files Browse the repository at this point in the history
Fixes #19146

Closes #19725.

Commit
e55fee2

PiperOrigin-RevId: 573751305
Change-Id: I9b5df85dc5e52822b3a0b44fc42d90b727a5abf0

Co-authored-by: Thi Don <[email protected]>
  • Loading branch information
iancha1992 and thii authored Oct 16, 2023
1 parent 90f08c4 commit 1799886
Show file tree
Hide file tree
Showing 2 changed files with 61 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 @@ -311,7 +311,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 @@ -2004,6 +2004,63 @@ public void testImplementationDepsLinkingContextIsPropagated() throws Exception
.contains("bin foo/libimplementation_dep.a");
}

@Test
public void testImplementationDepsDebugContextIsPropagated() throws Exception {
useConfiguration(
"--experimental_cc_implementation_deps",
"--fission=yes",
"--features=per_object_debug_info");
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 1799886

Please sign in to comment.