[Lldb-commits] [lldb] b833898 - [lldb] Add std::array to the supported template list of the CxxModuleHandler

Raphael Isemann via lldb-commits lldb-commits at lists.llvm.org
Thu Dec 17 02:48:19 PST 2020


Author: Raphael Isemann
Date: 2020-12-17T11:47:58+01:00
New Revision: b8338983e6f6ec6ebd48a7fc640b5d859e653b27

URL: https://github.com/llvm/llvm-project/commit/b8338983e6f6ec6ebd48a7fc640b5d859e653b27
DIFF: https://github.com/llvm/llvm-project/commit/b8338983e6f6ec6ebd48a7fc640b5d859e653b27.diff

LOG: [lldb] Add std::array to the supported template list of the CxxModuleHandler

Identical to the other patches that add STL containers to the supported
templated list.

Added: 
    lldb/test/API/commands/expression/import-std-module/array/Makefile
    lldb/test/API/commands/expression/import-std-module/array/TestArrayFromStdModule.py
    lldb/test/API/commands/expression/import-std-module/array/main.cpp

Modified: 
    lldb/source/Plugins/ExpressionParser/Clang/CxxModuleHandler.cpp

Removed: 
    


################################################################################
diff  --git a/lldb/source/Plugins/ExpressionParser/Clang/CxxModuleHandler.cpp b/lldb/source/Plugins/ExpressionParser/Clang/CxxModuleHandler.cpp
index 8a8450245990..f953e860969c 100644
--- a/lldb/source/Plugins/ExpressionParser/Clang/CxxModuleHandler.cpp
+++ b/lldb/source/Plugins/ExpressionParser/Clang/CxxModuleHandler.cpp
@@ -22,6 +22,7 @@ CxxModuleHandler::CxxModuleHandler(ASTImporter &importer, ASTContext *target)
 
   std::initializer_list<const char *> supported_names = {
       // containers
+      "array",
       "deque",
       "forward_list",
       "list",

diff  --git a/lldb/test/API/commands/expression/import-std-module/array/Makefile b/lldb/test/API/commands/expression/import-std-module/array/Makefile
new file mode 100644
index 000000000000..f938f7428468
--- /dev/null
+++ b/lldb/test/API/commands/expression/import-std-module/array/Makefile
@@ -0,0 +1,3 @@
+USE_LIBCPP := 1
+CXX_SOURCES := main.cpp
+include Makefile.rules

diff  --git a/lldb/test/API/commands/expression/import-std-module/array/TestArrayFromStdModule.py b/lldb/test/API/commands/expression/import-std-module/array/TestArrayFromStdModule.py
new file mode 100644
index 000000000000..ba9a7853b2f6
--- /dev/null
+++ b/lldb/test/API/commands/expression/import-std-module/array/TestArrayFromStdModule.py
@@ -0,0 +1,86 @@
+"""
+Test basic std::array functionality.
+"""
+
+from lldbsuite.test.decorators import *
+from lldbsuite.test.lldbtest import *
+from lldbsuite.test import lldbutil
+
+
+class TestCase(TestBase):
+
+    mydir = TestBase.compute_mydir(__file__)
+
+    @add_test_categories(["libc++"])
+    @skipIf(compiler=no_match("clang"))
+    def test(self):
+        self.build()
+
+        lldbutil.run_to_source_breakpoint(self,
+                                          "// Set break point at this line.",
+                                          lldb.SBFileSpec("main.cpp"))
+
+        self.runCmd("settings set target.import-std-module true")
+
+
+        # Test inspecting an array of integers.
+        array_type = "std::array<int, 3>"
+        size_type = "std::array::size_type"
+        value_type = array_type + "::value_type"
+
+        iterator = array_type + "::iterator"
+        riterator = array_type + "::reverse_iterator"
+
+        self.expect_expr("a",
+                         result_type=array_type,
+                         result_children=[
+                             ValueCheck(name="__elems_", children=[
+                                 ValueCheck(value="3"),
+                                 ValueCheck(value="1"),
+                                 ValueCheck(value="2"),
+                             ])
+                         ])
+        self.expect_expr("a.size()", result_type=size_type, result_value="3")
+        self.expect_expr("a.front()", result_type=value_type, result_value="3")
+        self.expect_expr("a[1]", result_type=value_type, result_value="1")
+        self.expect_expr("a.back()", result_type=value_type, result_value="2")
+
+        # Both are just pointers to the underlying elements.
+        self.expect_expr("a.begin()", result_type=iterator)
+        self.expect_expr("a.rbegin()", result_type=riterator)
+
+        self.expect_expr("*a.begin()", result_type=value_type, result_value="3")
+        self.expect_expr("*a.rbegin()", result_type="int", result_value="2")
+
+        self.expect_expr("a.at(0)", result_type=value_type, result_value="3")
+
+
+        # Same again with an array that has an element type from debug info.
+        array_type = "std::array<DbgInfo, 1>"
+        size_type = "std::array::size_type"
+        value_type = array_type + "::value_type"
+
+        iterator = array_type + "::iterator"
+        riterator = array_type + "::reverse_iterator"
+        dbg_info_elem_children = [ValueCheck(value="4")]
+        dbg_info_elem = [ValueCheck(children=dbg_info_elem_children)]
+
+        self.expect_expr("b",
+                         result_type=array_type,
+                         result_children=[
+                             ValueCheck(name="__elems_", children=dbg_info_elem)
+                         ])
+        self.expect_expr("b.size()", result_type=size_type, result_value="1")
+        self.expect_expr("b.front()", result_type=value_type, result_children=dbg_info_elem_children)
+        self.expect_expr("b[0]", result_type=value_type, result_children=dbg_info_elem_children)
+        self.expect_expr("b.back()", result_type=value_type, result_children=dbg_info_elem_children)
+
+        # Both are just pointers to the underlying elements.
+        self.expect_expr("b.begin()", result_type=iterator)
+        self.expect_expr("b.rbegin()", result_type=riterator)
+
+        self.expect_expr("*b.begin()", result_type=value_type, result_children=dbg_info_elem_children)
+        self.expect_expr("*b.rbegin()", result_type="DbgInfo", result_children=dbg_info_elem_children)
+
+        self.expect_expr("b.at(0)", result_type=value_type, result_children=dbg_info_elem_children)
+

diff  --git a/lldb/test/API/commands/expression/import-std-module/array/main.cpp b/lldb/test/API/commands/expression/import-std-module/array/main.cpp
new file mode 100644
index 000000000000..9bcd0b574042
--- /dev/null
+++ b/lldb/test/API/commands/expression/import-std-module/array/main.cpp
@@ -0,0 +1,11 @@
+#include <array>
+
+struct DbgInfo {
+  int v = 4;
+};
+
+int main(int argc, char **argv) {
+  std::array<int, 3> a = {3, 1, 2};
+  std::array<DbgInfo, 1> b{DbgInfo()};
+  return 0; // Set break point at this line.
+}


        


More information about the lldb-commits mailing list