This revision was landed with ongoing or failed builds. This revision was automatically updated to reflect the committed changes. Closed by commit rGd7363397c669: [lldb] Add typedefs to the DeclContext they are created in (authored by labath).
Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D86140/new/ https://reviews.llvm.org/D86140 Files: lldb/packages/Python/lldbsuite/test/lldbtest.py lldb/source/Plugins/TypeSystem/Clang/TypeSystemClang.cpp lldb/test/API/lang/cpp/typedef/TestCppTypedef.py lldb/test/API/lang/cpp/typedef/main.cpp Index: lldb/test/API/lang/cpp/typedef/main.cpp =================================================================== --- lldb/test/API/lang/cpp/typedef/main.cpp +++ lldb/test/API/lang/cpp/typedef/main.cpp @@ -7,7 +7,16 @@ typedef S<float> SF; +namespace ns { +typedef S<float> SF; +} +struct ST { + typedef S<float> SF; +}; + int main (int argc, char const *argv[]) { SF s{ .5 }; + ns::SF in_ns; + ST::SF in_struct; return 0; // Set a breakpoint here } Index: lldb/test/API/lang/cpp/typedef/TestCppTypedef.py =================================================================== --- lldb/test/API/lang/cpp/typedef/TestCppTypedef.py +++ lldb/test/API/lang/cpp/typedef/TestCppTypedef.py @@ -29,8 +29,16 @@ # First of all, check that we can get a typedefed type correctly in a simple case - expr_result = frame.EvaluateExpression("(SF)s") - self.assertTrue(expr_result.IsValid(), "Expression failed with: " + str(expr_result.GetError())) + expr_result = self.expect_expr("(SF)s", result_children=[ValueCheck(value="0.5")]) + self.expect_expr("(ns::SF)s", result_children=[ValueCheck(value="0.5")]) + self.expect_expr("(ST::SF)s", result_children=[ValueCheck(value="0.5")]) + + self.filecheck("image dump ast a.out", __file__, "--strict-whitespace") +# CHECK: {{^}}|-TypedefDecl {{.*}} SF 'S<float>' +# CHECK: {{^}}|-NamespaceDecl {{.*}} ns +# CHECK-NEXT: {{^}}| `-TypedefDecl {{.*}} SF 'S<float>' +# CHECK: {{^}}`-CXXRecordDecl {{.*}} struct ST definition +# CHECK: {{^}} `-TypedefDecl {{.*}} SF 'S<float>' typedef_type = expr_result.GetType(); self.assertTrue(typedef_type.IsValid(), "Can't get `SF` type of evaluated expression") Index: lldb/source/Plugins/TypeSystem/Clang/TypeSystemClang.cpp =================================================================== --- lldb/source/Plugins/TypeSystem/Clang/TypeSystemClang.cpp +++ lldb/source/Plugins/TypeSystem/Clang/TypeSystemClang.cpp @@ -4495,6 +4495,7 @@ clang_ast, decl_ctx, clang::SourceLocation(), clang::SourceLocation(), &clang_ast.Idents.get(typedef_name), clang_ast.getTrivialTypeSourceInfo(qual_type)); + decl_ctx->addDecl(decl); SetOwningModule(decl, TypePayloadClang(payload).GetOwningModule()); clang::TagDecl *tdecl = nullptr; Index: lldb/packages/Python/lldbsuite/test/lldbtest.py =================================================================== --- lldb/packages/Python/lldbsuite/test/lldbtest.py +++ lldb/packages/Python/lldbsuite/test/lldbtest.py @@ -2538,6 +2538,7 @@ value_check = ValueCheck(type=result_type, value=result_value, summary=result_summary, children=result_children) value_check.check_value(self, eval_result, str(eval_result)) + return eval_result def invoke(self, obj, name, trace=False): """Use reflection to call a method dynamically with no argument."""
Index: lldb/test/API/lang/cpp/typedef/main.cpp =================================================================== --- lldb/test/API/lang/cpp/typedef/main.cpp +++ lldb/test/API/lang/cpp/typedef/main.cpp @@ -7,7 +7,16 @@ typedef S<float> SF; +namespace ns { +typedef S<float> SF; +} +struct ST { + typedef S<float> SF; +}; + int main (int argc, char const *argv[]) { SF s{ .5 }; + ns::SF in_ns; + ST::SF in_struct; return 0; // Set a breakpoint here } Index: lldb/test/API/lang/cpp/typedef/TestCppTypedef.py =================================================================== --- lldb/test/API/lang/cpp/typedef/TestCppTypedef.py +++ lldb/test/API/lang/cpp/typedef/TestCppTypedef.py @@ -29,8 +29,16 @@ # First of all, check that we can get a typedefed type correctly in a simple case - expr_result = frame.EvaluateExpression("(SF)s") - self.assertTrue(expr_result.IsValid(), "Expression failed with: " + str(expr_result.GetError())) + expr_result = self.expect_expr("(SF)s", result_children=[ValueCheck(value="0.5")]) + self.expect_expr("(ns::SF)s", result_children=[ValueCheck(value="0.5")]) + self.expect_expr("(ST::SF)s", result_children=[ValueCheck(value="0.5")]) + + self.filecheck("image dump ast a.out", __file__, "--strict-whitespace") +# CHECK: {{^}}|-TypedefDecl {{.*}} SF 'S<float>' +# CHECK: {{^}}|-NamespaceDecl {{.*}} ns +# CHECK-NEXT: {{^}}| `-TypedefDecl {{.*}} SF 'S<float>' +# CHECK: {{^}}`-CXXRecordDecl {{.*}} struct ST definition +# CHECK: {{^}} `-TypedefDecl {{.*}} SF 'S<float>' typedef_type = expr_result.GetType(); self.assertTrue(typedef_type.IsValid(), "Can't get `SF` type of evaluated expression") Index: lldb/source/Plugins/TypeSystem/Clang/TypeSystemClang.cpp =================================================================== --- lldb/source/Plugins/TypeSystem/Clang/TypeSystemClang.cpp +++ lldb/source/Plugins/TypeSystem/Clang/TypeSystemClang.cpp @@ -4495,6 +4495,7 @@ clang_ast, decl_ctx, clang::SourceLocation(), clang::SourceLocation(), &clang_ast.Idents.get(typedef_name), clang_ast.getTrivialTypeSourceInfo(qual_type)); + decl_ctx->addDecl(decl); SetOwningModule(decl, TypePayloadClang(payload).GetOwningModule()); clang::TagDecl *tdecl = nullptr; Index: lldb/packages/Python/lldbsuite/test/lldbtest.py =================================================================== --- lldb/packages/Python/lldbsuite/test/lldbtest.py +++ lldb/packages/Python/lldbsuite/test/lldbtest.py @@ -2538,6 +2538,7 @@ value_check = ValueCheck(type=result_type, value=result_value, summary=result_summary, children=result_children) value_check.check_value(self, eval_result, str(eval_result)) + return eval_result def invoke(self, obj, name, trace=False): """Use reflection to call a method dynamically with no argument."""
_______________________________________________ lldb-commits mailing list lldb-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits