summaryrefslogtreecommitdiffstats
path: root/debuginfo-tests/nested-struct.cpp
diff options
context:
space:
mode:
authorZachary Turner <zturner@google.com>2017-11-17 00:41:18 +0000
committerZachary Turner <zturner@google.com>2017-11-17 00:41:18 +0000
commitb5c237ec3d5f708e7118913923f3d50359dff40a (patch)
treeb438760cb6dcd11f4a68498b270b55af373a95b4 /debuginfo-tests/nested-struct.cpp
parent2f2ace985de421f9a4ff793ae2520ae91ecd4f0a (diff)
downloadbcm5719-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.cpp21
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;
+}
OpenPOWER on IntegriCloud