llvm-project/lldb/unittests/TestingSupport
Adrian Prantl 6eaedbb52f Make CompilerType safe
When a process gets restarted TypeSystem objects associated with it
may get deleted, and any CompilerType objects holding on to a
reference to that type system are a use-after-free in waiting. Because
of the SBAPI, we don't have tight control over where CompilerTypes go
and when they are used. This is particularly a problem in the Swift
plugin, where the scratch TypeSystem can be restarted while the
process is still running. The Swift plugin has a lock to prevent
abuse, but where there's a lock there can be bugs.

This patch changes CompilerType to store a std::weak_ptr<TypeSystem>.
Most of the std::weak_ptr<TypeSystem>* uglyness is hidden by
introducing a wrapper class CompilerType::WrappedTypeSystem that has a
dyn_cast_or_null() method. The only sites that need to know about the
weak pointer implementation detail are the ones that deal with
creating TypeSystems.

rdar://101505232

Differential Revision: https://reviews.llvm.org/D136650
2022-11-16 15:51:26 -08:00
..
Host [test] Use either `127.0.0.1` or `[::1]` to run in ipv6-only environments. 2022-09-09 14:00:35 -07:00
Symbol Make CompilerType safe 2022-11-16 15:51:26 -08:00
CMakeLists.txt [lldb] Make CommunicationTest compatible with windows 2022-08-26 15:25:46 +02:00
MockTildeExpressionResolver.cpp Add missing STLExtras.h include from lldb/unittests/TestingSupport/MockTildeExpressionResolver.cpp 2022-01-24 15:03:11 +01:00
MockTildeExpressionResolver.h
SubsystemRAII.h
TestUtilities.cpp
TestUtilities.h
module.modulemap