[6.0][Concurrency] Don't diagnose nonisolated(unsafe)
properties during flow isolation.
#73311
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.
Explanation: Flow isolation was not allowing access to
nonisolated(unsafe)
properties inside actor inits/deinit, leading to warnings in the following code from Cannot access nonisolated(unsafe) var property of actor from init #73294:This change prevents flow isolation from diagnosing
nonisolated(unsafe)
properties by checking forActorIsolation::NonisolatedUnsafe
invarIsSafeAcrossActors
.Scope: Only impacts access to
nonisolated(unsafe)
properties inside actorinit
s anddeinit
s.Risk: Low; this change allows more code to compile under the Swift 6 language mode, and the only impact in other language modes is fewer warnings under
-strict-concurrency=complete
. This change has no impact on code that uses-strict-concurrency=minimal
.Testing: Added a new test.
Main branch PR: [Concurrency] Don't diagnose
nonisolated(unsafe)
properties during flow isolation. #73308