[6.0] Sema: Fix existential-metatype-to-Any conversion #72808
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
6.0 cherry-pick of #72762 and #72789.
Description: The type checker incorrectly used the instance type of a metatype instead of the metatype itself when looking up a conformance, which caused an invariant violation in the SILCloner. This PR supersedes an earlier workaround. This PR also cherry-picks some regression tests for bugs that are already fixed on the 6.0 branch.
Scope of the issue: Various projects hit this specifically with the
any Any.Type
toAny
conversion.Origination: This was a regression since enablement of non copyable generics and didn't ship in a release.
Radar: rdar://125460667
Reviewed by: @kavon