[Lldb-commits] [PATCH] D70415: Complete complete types early when importing types from Clang module DWARF.

Adrian Prantl via Phabricator via lldb-commits lldb-commits at lists.llvm.org
Mon Nov 18 17:40:22 PST 2019


aprantl created this revision.
aprantl added reviewers: jingham, shafik, jasonmolenda, clayborg.
Herald added a project: LLDB.

This affects -gmodules only.

Under normal operation pcm_type is a shallow forward declaration
that gets completed later. This is necessary to support cyclic
data structures. If, however, pcm_type is already complete (for
example, because it was loaded for a different target before),
the definition needs to be imported right away, too.
Type::ResolveClangType() effectively ignores the ResolveState
inside type_sp and only looks at IsDefined(), so it never calls
ClangASTImporter::ASTImporterDelegate::ImportDefinitionTo(),
which does extra work for Objective-C classes. This would result
in only the forward declaration to be visible.

An alternative implementation would be to sink this into Type::ResolveClangType ( https://github.com/llvm/llvm-project/blob/88235812a71d99c082e7aa2ef9356d43d1f83a80/lldb/source/Symbol/Type.cpp#L589) though it isn't clear to me how to best do this from a layering perspective.

rdar://problem/52134074


Repository:
  rG LLVM Github Monorepo

https://reviews.llvm.org/D70415

Files:
  lldb/packages/Python/lldbsuite/test/lang/objc/modules-app-update/Makefile
  lldb/packages/Python/lldbsuite/test/lang/objc/modules-app-update/TestClangModulesAppUpdate.py
  lldb/packages/Python/lldbsuite/test/lang/objc/modules-app-update/foo.m
  lldb/packages/Python/lldbsuite/test/lang/objc/modules-app-update/main.m
  lldb/packages/Python/lldbsuite/test/lang/objc/modules-app-update/module.modulemap
  lldb/packages/Python/lldbsuite/test/lang/objc/modules-app-update/umbrella.h
  lldb/source/Plugins/SymbolFile/DWARF/DWARFASTParserClang.cpp

-------------- next part --------------
A non-text attachment was scrubbed...
Name: D70415.229952.patch
Type: text/x-patch
Size: 6053 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/lldb-commits/attachments/20191119/21009a67/attachment.bin>


More information about the lldb-commits mailing list