Actor Isolation Fixer
SKILL.md
Actor Isolation Fixer
Instructions
Fix actor isolation errors systematically:
-
Error: "main actor-isolated property X cannot be accessed from nonisolated"
- In deinit: Mark property as
nonisolated(unsafe) private var - In closure: Add
@MainActorto Task or useawait MainActor.run { } - In method: Mark method
@MainActorornonisolated
- In deinit: Mark property as
-
Common Leavn patterns:
// Timer in @MainActor class deinit nonisolated(unsafe) private var timer: Timer? deinit { timer?.invalidate() // Safe - Timer.invalidate() is thread-safe } // Task property in @MainActor class nonisolated(unsafe) private var task: Task<Void, Never>? deinit { task?.cancel() // Safe - Task.cancel() is thread-safe } -
Don't use nonisolated(unsafe) for:
- UI properties (views, layers)
- Mutable state accessed across threads
- Non-thread-safe types
-
Safe to use nonisolated(unsafe) for:
- Timers (invalidate is thread-safe)
- Tasks (cancel is thread-safe)
- Notification observers (removeObserver is thread-safe)
Use this skill when: Actor isolation errors, deinit cannot access properties, concurrent access violations