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/nrvo-string.cpp | |
parent | 2f2ace985de421f9a4ff793ae2520ae91ecd4f0a (diff) | |
download | llvm-b5c237ec3d5f708e7118913923f3d50359dff40a.zip llvm-b5c237ec3d5f708e7118913923f3d50359dff40a.tar.gz llvm-b5c237ec3d5f708e7118913923f3d50359dff40a.tar.bz2 |
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/nrvo-string.cpp')
-rw-r--r-- | debuginfo-tests/nrvo-string.cpp | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/debuginfo-tests/nrvo-string.cpp b/debuginfo-tests/nrvo-string.cpp new file mode 100644 index 0000000..18acebb --- /dev/null +++ b/debuginfo-tests/nrvo-string.cpp @@ -0,0 +1,27 @@ +// This ensures that DW_OP_deref is inserted when necessary, such as when NRVO +// of a string object occurs in C++. +// +// RUN: %clangxx -O0 -fno-exceptions %target_itanium_abi_host_triple %s -o %t.out -g +// RUN: %test_debuginfo %s %t.out +// RUN: %clangxx -O1 -fno-exceptions %target_itanium_abi_host_triple %s -o %t.out -g +// RUN: %test_debuginfo %s %t.out +// +// PR34513 + +struct string { + string() {} + string(int i) : i(i) {} + ~string() {} + int i = 0; +}; +string get_string() { + string unused; + string result = 3; +// DEBUGGER: break 21 + return result; +} +int main() { get_string(); } + +// DEBUGGER: r +// DEBUGGER: print result.i +// CHECK: = 3 |