[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