This is still broken because it causes certain tests to be
run twice with slightly different configurations, which is
wrong in some cases.
You can observe this by running:
ninja -nv check-all | grep debuginfo-tests
And seeing that it passes clang/test and clang/test/debuginfo-tests
to lit, which causes it to run debuginfo-tests twice. The fix is
going to involve either:
a) figuring out that we're running in this "deprecated" configuration,
and then deleting the clang/test/debuginfo-tests path, which should
cause it to behave identically to before, or:
b) make lit smart enough that it doesn't descend into a sub-suite if
that sub-suite already has a lit.cfg file.
llvm-svn: 318486
22 lines
485 B
C++
22 lines
485 B
C++
// RUN: %clangxx %target_itanium_abi_host_triple -O0 -g %s -c -o %t.o
|
|
// RUN: %test_debuginfo %s %t.o
|
|
// Radar 9440721
|
|
// If debug info for my_number() is emitted outside function foo's scope
|
|
// then a debugger may not be able to handle it. At least one version of
|
|
// gdb crashes in such cases.
|
|
|
|
// DEBUGGER: ptype foo
|
|
// CHECK: int (void)
|
|
|
|
int foo() {
|
|
struct Local {
|
|
static int my_number() {
|
|
return 42;
|
|
}
|
|
};
|
|
|
|
int i = 0;
|
|
i = Local::my_number();
|
|
return i + 1;
|
|
}
|