[lldb] Remove modern-type-lookup
authorRaphael Isemann <teemperor@gmail.com>
Tue, 17 Dec 2019 11:22:34 +0000 (12:22 +0100)
committerRaphael Isemann <teemperor@gmail.com>
Tue, 17 Dec 2019 11:24:31 +0000 (12:24 +0100)
commitff0102b32cfe506dfc16a86e38e70b0940697aa2
tree5ca3f549f0f4768a7f8b95af6297382a521de7ed
parentdf5a905aa8a868bdb700d88e427491ee56243e30
[lldb] Remove modern-type-lookup

Summary:
As discussed on the mailing list [1] we have to make a decision for how to proceed with the modern-type-lookup.

This patch removes modern-type-lookup from LLDB. This just removes all the code behind the modern-type-lookup
setting but it does *not* remove any code from Clang (i.e., the ExternalASTMerger and the clang-import-test stay around
for now).

The motivation for this is that I don't think that the current approach of implementing modern-type-lookup
will work out. Especially creating a completely new lookup system behind some setting that is never turned on by anyone
and then one day make one big switch to the new system seems wrong. It doesn't fit into the way LLVM is developed and has
so far made the transition work much more complicated than it has to be.

A lot of the benefits that were supposed to come with the modern-type-lookup are related to having a better organization
in the way types move across LLDB and having less dependencies on unrelated LLDB code. By just looking at the current code (mostly
the ClangASTImporter) I think we can reach the same goals by just incrementally cleaning up, documenting, refactoring
and actually testing the existing code we have.

[1] http://lists.llvm.org/pipermail/lldb-dev/2019-December/015831.html

Reviewers: shafik, martong

Subscribers: rnkovacs, christof, arphaman, JDevlieghere, usaxena95, lldb-commits, friss

Tags: #lldb

Differential Revision: https://reviews.llvm.org/D71562
24 files changed:
lldb/include/lldb/Symbol/ClangASTContext.h
lldb/include/lldb/Target/Target.h
lldb/packages/Python/lldbsuite/test/functionalities/modern-type-lookup/basic-objc/Makefile [deleted file]
lldb/packages/Python/lldbsuite/test/functionalities/modern-type-lookup/basic-objc/TestBasicObjcModernTypeLookup.py [deleted file]
lldb/packages/Python/lldbsuite/test/functionalities/modern-type-lookup/basic-objc/main.m [deleted file]
lldb/packages/Python/lldbsuite/test/functionalities/modern-type-lookup/basic/Makefile [deleted file]
lldb/packages/Python/lldbsuite/test/functionalities/modern-type-lookup/basic/TestBasicModernTypeLookup.py [deleted file]
lldb/packages/Python/lldbsuite/test/functionalities/modern-type-lookup/basic/main.cpp [deleted file]
lldb/packages/Python/lldbsuite/test/functionalities/modern-type-lookup/libcxx/Makefile [deleted file]
lldb/packages/Python/lldbsuite/test/functionalities/modern-type-lookup/libcxx/TestLibCxxModernTypeLookup.py [deleted file]
lldb/packages/Python/lldbsuite/test/functionalities/modern-type-lookup/libcxx/main.cpp [deleted file]
lldb/packages/Python/lldbsuite/test/functionalities/modern-type-lookup/objc-modules/Makefile [deleted file]
lldb/packages/Python/lldbsuite/test/functionalities/modern-type-lookup/objc-modules/TestObjModulesModernTypeLookup.py [deleted file]
lldb/packages/Python/lldbsuite/test/functionalities/modern-type-lookup/objc-modules/main.m [deleted file]
lldb/source/Plugins/ExpressionParser/Clang/ClangASTSource.cpp
lldb/source/Plugins/ExpressionParser/Clang/ClangASTSource.h
lldb/source/Plugins/ExpressionParser/Clang/ClangDeclVendor.h
lldb/source/Plugins/ExpressionParser/Clang/ClangExpressionDeclMap.cpp
lldb/source/Plugins/ExpressionParser/Clang/ClangModulesDeclVendor.cpp
lldb/source/Plugins/LanguageRuntime/ObjC/AppleObjCRuntime/AppleObjCDeclVendor.cpp
lldb/source/Plugins/LanguageRuntime/ObjC/AppleObjCRuntime/AppleObjCDeclVendor.h
lldb/source/Symbol/ClangASTContext.cpp
lldb/source/Target/Target.cpp
lldb/source/Target/TargetProperties.td