[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