summaryrefslogtreecommitdiffstats
path: root/lldb/source/Expression/DWARFExpression.cpp
diff options
context:
space:
mode:
authorGreg Clayton <gclayton@apple.com>2010-09-29 01:12:09 +0000
committerGreg Clayton <gclayton@apple.com>2010-09-29 01:12:09 +0000
commit1be10fca5f2b290b956710d9c03c14b0c82f7ef4 (patch)
tree4036af6f55e00076d5e2a9ee849bbcf628a39277 /lldb/source/Expression/DWARFExpression.cpp
parentedd4b600f3016b1ef1c3e39c3f495c524f600fa5 (diff)
downloadbcm5719-llvm-1be10fca5f2b290b956710d9c03c14b0c82f7ef4.tar.gz
bcm5719-llvm-1be10fca5f2b290b956710d9c03c14b0c82f7ef4.zip
Fixed the forward declaration issue that was present in the DWARF parser after
adding methods to C++ and objective C classes. In order to make methods, we need the function prototype which means we need the arguments. Parsing these could cause a circular reference that caused an assertion. Added a new typedef for the clang opaque types which are just void pointers: lldb::clang_type_t. This appears in lldb-types.h. This was fixed by enabling struct, union, class, and enum types to only get a forward declaration when we make the clang opaque qual type for these types. When they need to actually be resolved, lldb_private::Type will call a new function in the SymbolFile protocol to resolve a clang type when it is not fully defined (clang::TagDecl::getDefinition() returns NULL). This allows us to be a lot more lazy when parsing clang types and keeps down the amount of data that gets parsed into the ASTContext for each module. Getting the clang type from a "lldb_private::Type" object now takes a boolean that indicates if a forward declaration is ok: clang_type_t lldb_private::Type::GetClangType (bool forward_decl_is_ok); So function prototypes that define parameters that are "const T&" can now just parse the forward declaration for type 'T' and we avoid circular references in the type system. llvm-svn: 115012
Diffstat (limited to 'lldb/source/Expression/DWARFExpression.cpp')
-rw-r--r--lldb/source/Expression/DWARFExpression.cpp8
1 files changed, 4 insertions, 4 deletions
diff --git a/lldb/source/Expression/DWARFExpression.cpp b/lldb/source/Expression/DWARFExpression.cpp
index a29994ef4b0..eef35a1df31 100644
--- a/lldb/source/Expression/DWARFExpression.cpp
+++ b/lldb/source/Expression/DWARFExpression.cpp
@@ -2136,7 +2136,7 @@ DWARFExpression::Evaluate
return false;
}
- void *array_type = array_val.GetOpaqueClangQualType();
+ void *array_type = array_val.GetClangType();
void *member_type;
uint64_t size = 0;
@@ -2214,7 +2214,7 @@ DWARFExpression::Evaluate
{
case Value::eContextTypeOpaqueClangQualType:
{
- void *clang_type = stack.back().GetOpaqueClangQualType();
+ void *clang_type = stack.back().GetClangType();
if (ClangASTContext::IsAggregateType (clang_type))
{
@@ -2434,7 +2434,7 @@ DWARFExpression::Evaluate
return false;
}
- void *ptr_type = tmp.GetOpaqueClangQualType();
+ void *ptr_type = tmp.GetClangType();
void *target_type;
if (!ClangASTContext::IsPointerType(ptr_type, &target_type))
@@ -2483,7 +2483,7 @@ DWARFExpression::Evaluate
Value *proxy = expr_local_variable->CreateProxy();
stack.push_back(*proxy);
delete proxy;
- //stack.back().SetContext (Value::eContextTypeOpaqueClangQualType, expr_local_variable->GetOpaqueClangQualType());
+ //stack.back().SetContext (Value::eContextTypeOpaqueClangQualType, expr_local_variable->GetClangType());
*/
}
break;
OpenPOWER on IntegriCloud