summaryrefslogtreecommitdiffstats
path: root/lldb/packages/Python/lldbsuite
diff options
context:
space:
mode:
authorRaphael Isemann <teemperor@gmail.com>2019-07-21 10:31:13 +0000
committerRaphael Isemann <teemperor@gmail.com>2019-07-21 10:31:13 +0000
commitca9dfdfaecaa13fc075858a2965fd2f43e7bc8e1 (patch)
treee383985c1218ba0a4a898c1fb4e452e98608e92b /lldb/packages/Python/lldbsuite
parent8a431874e995b3ff3c4c99a23cfed0429cc9f117 (diff)
downloadbcm5719-llvm-ca9dfdfaecaa13fc075858a2965fd2f43e7bc8e1.tar.gz
bcm5719-llvm-ca9dfdfaecaa13fc075858a2965fd2f43e7bc8e1.zip
[lldb] Fix crash when looking up type coming from the ClangModuleDeclVendor
Summary: We assume in LLDB that every type comes from an ASTContext with an associated ClangASTContext. However the types inside the ClangModuleDeclVendor don't have a ClangASTContext so we end up crashing whenever we create a CompilerType for one of these types. Simplest way to trigger this bug is to just look up NSObject from a module: (lldb) expr @import Foundation (lldb) type lookup NSObject Assertion failed: (m_type_system != nullptr), function CompilerType, file /Users/teemperor/llvm1/llvm-project/lldb/source/Symbol/CompilerType.cpp, line 39. This patch just creates a ClangASTContext for the ASTContext used by ClangModuleDeclVendor. Reviewers: davide, shafik Reviewed By: davide Subscribers: lldb-commits Tags: #lldb Differential Revision: https://reviews.llvm.org/D64989 llvm-svn: 366653
Diffstat (limited to 'lldb/packages/Python/lldbsuite')
-rw-r--r--lldb/packages/Python/lldbsuite/test/lang/objc/modules/TestObjCModules.py4
1 files changed, 4 insertions, 0 deletions
diff --git a/lldb/packages/Python/lldbsuite/test/lang/objc/modules/TestObjCModules.py b/lldb/packages/Python/lldbsuite/test/lang/objc/modules/TestObjCModules.py
index 8f5c407000c..4e40c58effa 100644
--- a/lldb/packages/Python/lldbsuite/test/lang/objc/modules/TestObjCModules.py
+++ b/lldb/packages/Python/lldbsuite/test/lang/objc/modules/TestObjCModules.py
@@ -60,6 +60,10 @@ class ObjCModulesTestCase(TestBase):
"int",
"4"])
+ # Type lookup should still work and print something reasonable
+ # for types from the module.
+ self.expect("type lookup NSObject", substrs=["instanceMethod"])
+
self.expect("expr string.length", VARIABLES_DISPLAYED_CORRECTLY,
substrs=["NSUInteger", "5"])
OpenPOWER on IntegriCloud