diff options
author | Zachary Turner <zturner@google.com> | 2017-11-17 00:41:18 +0000 |
---|---|---|
committer | Zachary Turner <zturner@google.com> | 2017-11-17 00:41:18 +0000 |
commit | b5c237ec3d5f708e7118913923f3d50359dff40a (patch) | |
tree | b438760cb6dcd11f4a68498b270b55af373a95b4 /debuginfo-tests/nested-struct.cpp | |
parent | 2f2ace985de421f9a4ff793ae2520ae91ecd4f0a (diff) | |
download | bcm5719-llvm-b5c237ec3d5f708e7118913923f3d50359dff40a.tar.gz bcm5719-llvm-b5c237ec3d5f708e7118913923f3d50359dff40a.zip |
Re-revert "Refactor debuginfo-tests"
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
Diffstat (limited to 'debuginfo-tests/nested-struct.cpp')
-rw-r--r-- | debuginfo-tests/nested-struct.cpp | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/debuginfo-tests/nested-struct.cpp b/debuginfo-tests/nested-struct.cpp new file mode 100644 index 00000000000..7533e6a8151 --- /dev/null +++ b/debuginfo-tests/nested-struct.cpp @@ -0,0 +1,21 @@ +// 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; +} |