mirror of
https://github.com/intel/llvm.git
synced 2026-01-16 21:55:39 +08:00
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
40 lines
814 B
C++
40 lines
814 B
C++
// RUN: %clangxx %target_itanium_abi_host_triple -O0 -g %s -o %t -c
|
|
// RUN: %clangxx %target_itanium_abi_host_triple %t -o %t.out
|
|
// RUN: %test_debuginfo %s %t.out
|
|
|
|
// FIXME: LLDB finds the wrong symbol for "C". rdar://problem/14933867
|
|
// XFAIL: darwin
|
|
|
|
// DEBUGGER: delete breakpoints
|
|
// DEBUGGER: break static-member.cpp:33
|
|
// DEBUGGER: r
|
|
// DEBUGGER: ptype C
|
|
// CHECK: {{struct|class}} C {
|
|
// CHECK: static const int a;
|
|
// CHECK-NEXT: static int b;
|
|
// CHECK-NEXT: static int c;
|
|
// CHECK-NEXT: int d;
|
|
// CHECK-NEXT: }
|
|
// DEBUGGER: p C::a
|
|
// CHECK: ${{[0-9]}} = 4
|
|
// DEBUGGER: p C::c
|
|
// CHECK: ${{[0-9]}} = 15
|
|
|
|
// PR14471, PR14734
|
|
|
|
class C {
|
|
public:
|
|
const static int a = 4;
|
|
static int b;
|
|
static int c;
|
|
int d;
|
|
};
|
|
|
|
int C::c = 15;
|
|
const int C::a;
|
|
|
|
int main() {
|
|
C instance_C;
|
|
return C::a;
|
|
}
|