[debuginfo-tests] r340189 - (Retry) Add a basic integration test for C++ smart pointers

Vedant Kumar via llvm-commits llvm-commits at lists.llvm.org
Mon Aug 20 10:17:38 PDT 2018


Author: vedantk
Date: Mon Aug 20 10:17:38 2018
New Revision: 340189

URL: http://llvm.org/viewvc/llvm-project?rev=340189&view=rev
Log:
(Retry) Add a basic integration test for C++ smart pointers

Check that the debugger can pretty-print unique_ptr and shared_ptr when
passed as a function argument.

This was reverted in r339961 because of a bug in the version of lldb
installed on the public Green Dragon builders.

rdar://42314305

Added:
    debuginfo-tests/trunk/smart-ptr-1.cpp

Added: debuginfo-tests/trunk/smart-ptr-1.cpp
URL: http://llvm.org/viewvc/llvm-project/debuginfo-tests/trunk/smart-ptr-1.cpp?rev=340189&view=auto
==============================================================================
--- debuginfo-tests/trunk/smart-ptr-1.cpp (added)
+++ debuginfo-tests/trunk/smart-ptr-1.cpp Mon Aug 20 10:17:38 2018
@@ -0,0 +1,41 @@
+// RUN: %clangxx -std=c++14 %target_itanium_abi_host_triple -g %s -o %t.O0.out
+// RUN: %test_debuginfo %s %t.O0.out
+// UNSUPPORTED: apple-lldb-pre-1000
+#include <memory>
+
+static volatile int sink;
+
+static void use_shared_ptr(std::shared_ptr<int> ptr) {
+  // DEBUGGER: break 10
+  sink = *ptr;
+}
+
+static void use_unique_ptr(std::unique_ptr<int> ptr) {
+  // DEBUGGER: break 15
+  sink = *ptr;
+}
+
+int main() {
+  auto sp_1 = std::make_shared<int>(1234);
+  use_shared_ptr(sp_1);
+
+  auto up_1 = std::make_unique<int>(5678);
+  use_unique_ptr(std::move(up_1));
+
+  return 0;
+}
+
+// DEBUGGER: r
+
+// (at line 10)
+// DEBUGGER: p ptr
+// CHECK: shared_ptr<int>
+// CHECK-SAME: 1234
+
+// DEBUGGER: c
+
+// (at line 16)
+// DEBUGGER: p ptr
+// CHECK: unique_ptr<int>
+// TODO: lldb's unique_ptr data formatter doesn't pretty-print its wrapped
+// object.




More information about the llvm-commits mailing list