forked from OSchip/llvm-project
[modules][debuginfo] Only include imported modules when targeting LLDB
These constructs are only applicable to a debugger capable of loading a Clang AST, so omit them for brevity when not doing so. We could potentially propagate more of CodeGenOptions through the ObjectFilePCGContainerOperations for consistency (so the next person who adds some CodeGenOpts feature that tweaks debug info output doesn't get caught by this), so I'm open to objections/alternatives there, but went with this for now. Tested just a couple of basic cases (one direct, one indirect (through the ObjectFilePCHContainerOperations) & fixed up other cases to pass the -debugger-tuning flag as appropriate. llvm-svn: 268460
This commit is contained in:
parent
43e3a64270
commit
af09f4ac72
|
@ -3505,6 +3505,8 @@ void CGDebugInfo::EmitUsingDecl(const UsingDecl &UD) {
|
|||
}
|
||||
|
||||
void CGDebugInfo::EmitImportDecl(const ImportDecl &ID) {
|
||||
if (CGM.getCodeGenOpts().getDebuggerTuning() != llvm::DebuggerKind::LLDB)
|
||||
return;
|
||||
if (Module *M = ID.getImportedModule()) {
|
||||
auto Info = ExternalASTSource::ASTSourceDescriptor(*M);
|
||||
DBuilder.createImportedDeclaration(
|
||||
|
|
|
@ -152,6 +152,7 @@ public:
|
|||
CodeGenOpts.ThreadModel = "single";
|
||||
CodeGenOpts.DebugTypeExtRefs = true;
|
||||
CodeGenOpts.setDebugInfo(codegenoptions::FullDebugInfo);
|
||||
CodeGenOpts.setDebuggerTuning(CI.getCodeGenOpts().getDebuggerTuning());
|
||||
}
|
||||
|
||||
~PCHContainerGenerator() override = default;
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
// RUN: rm -rf %t
|
||||
// RUN: %clang_cc1 -fmodules -fmodule-format=obj -debug-info-kind=limited -dwarf-ext-refs \
|
||||
// RUN: -fimplicit-module-maps -x c -fmodules-cache-path=%t -I %S/Inputs \
|
||||
// RUN: %s -emit-llvm -o - | FileCheck %s
|
||||
// RUN: %s -emit-llvm -debugger-tuning=lldb -o - | FileCheck %s
|
||||
#include "DebugSubmoduleA.h"
|
||||
#include "DebugSubmoduleB.h"
|
||||
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
// RUN: rm -rf %t
|
||||
// RUN: %clang_cc1 -fmodules -fmodule-format=obj -debug-info-kind=limited -dwarf-ext-refs \
|
||||
// RUN: -fimplicit-module-maps -fmodules-cache-path=%t -I %S/Inputs \
|
||||
// RUN: %s -mllvm -debug-only=pchcontainer 2>&1 | FileCheck %s
|
||||
// RUN: %s -mllvm -debug-only=pchcontainer -debugger-tuning=lldb 2>&1 | FileCheck %s
|
||||
// REQUIRES: asserts
|
||||
|
||||
@import diamond_left;
|
||||
|
@ -20,3 +20,9 @@
|
|||
// Skeleton for top:
|
||||
// CHECK: !DICompileUnit({{.*}}splitDebugFilename: {{.*}}diamond_top{{.*}}dwoId:
|
||||
|
||||
// RUN: rm -rf %t
|
||||
// RUN: %clang_cc1 -fmodules -fmodule-format=obj -debug-info-kind=limited -dwarf-ext-refs \
|
||||
// RUN: -fimplicit-module-maps -fmodules-cache-path=%t -I %S/Inputs \
|
||||
// RUN: %s -mllvm -debug-only=pchcontainer 2>&1 | FileCheck %s --check-prefix=NOIMPORT
|
||||
|
||||
// NOIMPORT-NOT: !DIImportedEntity
|
||||
|
|
|
@ -1,10 +1,16 @@
|
|||
// RUN: rm -rf %t
|
||||
// RUN: %clang_cc1 -debug-info-kind=limited -fmodules -DGREETING="Hello World" -UNDEBUG -fimplicit-module-maps -fmodules-cache-path=%t %s -I %S/Inputs -isysroot /tmp/.. -I %t -emit-llvm -o - | FileCheck %s
|
||||
// RUN: %clang_cc1 -debug-info-kind=limited -fmodules -DGREETING="Hello World" -UNDEBUG -fimplicit-module-maps -fmodules-cache-path=%t %s -I %S/Inputs -isysroot /tmp/.. -I %t -emit-llvm -o - | FileCheck %s --check-prefix=NOIMPORT
|
||||
|
||||
// NOIMPORT-NOT: !DIImportedEntity
|
||||
// NOIMPORT-NOT: !DIModule
|
||||
|
||||
// RUN: rm -rf %t
|
||||
// RUN: %clang_cc1 -debug-info-kind=limited -fmodules -DGREETING="Hello World" -UNDEBUG -fimplicit-module-maps -fmodules-cache-path=%t %s -I %S/Inputs -isysroot /tmp/.. -I %t -emit-llvm -debugger-tuning=lldb -o - | FileCheck %s
|
||||
|
||||
// CHECK: ![[CU:.*]] = distinct !DICompileUnit
|
||||
@import DebugObjC;
|
||||
// CHECK: !DIImportedEntity(tag: DW_TAG_imported_declaration, scope: ![[CU]],
|
||||
// CHECK-SAME: entity: ![[MODULE:.*]], line: 5)
|
||||
// CHECK-SAME: entity: ![[MODULE:.*]], line: [[@LINE-2]])
|
||||
// CHECK: ![[MODULE]] = !DIModule(scope: null, name: "DebugObjC",
|
||||
// CHECK-SAME: configMacros: "\22-DGREETING=Hello World\22 \22-UNDEBUG\22",
|
||||
// CHECK-SAME: includePath: "{{.*}}test{{.*}}Modules{{.*}}Inputs",
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
// RUN: %clang_cc1 -I %S/Inputs/getSourceDescriptor-crash -S -emit-llvm -debug-info-kind=limited -fimplicit-module-maps %s -o - | FileCheck %s
|
||||
// RUN: %clang_cc1 -I %S/Inputs/getSourceDescriptor-crash -S -emit-llvm -debug-info-kind=limited -debugger-tuning=lldb -fimplicit-module-maps %s -o - | FileCheck %s
|
||||
|
||||
#include "h1.h"
|
||||
#include "h1.h"
|
||||
|
|
Loading…
Reference in New Issue