.claude-plugin/plugins/axiom/skills/axiom-ios-concurrency/SKILL.md
Use when writing ANY code with async, actors, threads, or seeing ANY concurrency error. Covers Swift 6 concurrency, @MainActor, Sendable, data races, async/await patterns, performance optimization.
npx skillsauth add charleswiltgen/axiom axiom-ios-concurrencyInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
You MUST use this skill for ANY concurrency, async/await, threading, or Swift 6 concurrency work.
Use this router when:
ios-concurrency vs ios-performance: When app freezes or feels slow:
ios-concurrency vs ios-build: When seeing Swift 6 concurrency errors:
ios-concurrency vs ios-data: When concurrency errors involve Core Data or SwiftData:
Rationale: A 2-second freeze during data loading is almost always await on main thread or missing background dispatch. Domain knowledge solves this faster than Time Profiler. Core Data threading violations need Core Data-specific fixes, not generic concurrency patterns.
Swift 6 concurrency patterns → /skill axiom-swift-concurrency
Swift concurrency API reference → /skill axiom-swift-concurrency-ref
Swift performance → /skill axiom-swift-performance
Synchronous actor access → /skill axiom-assume-isolated
Thread-safe primitives → /skill axiom-synchronization
Parameter ownership → /skill axiom-ownership-conventions
Concurrency profiling → /skill axiom-concurrency-profiling
Combine reactive patterns → /skill axiom-combine-patterns
Concurrency audit → Launch concurrency-auditor agent or /axiom:audit concurrency (Swift 6 strict concurrency violations, unsafe Task captures, missing @MainActor, Sendable violations, actor isolation problems)
| Thought | Reality | |---------|---------| | "Just add @MainActor and it'll work" | @MainActor has isolation inheritance rules. swift-concurrency covers all patterns. | | "I'll use nonisolated(unsafe) to silence the warning" | Silencing warnings hides data races. swift-concurrency shows the safe pattern. | | "It's just one async call" | Even single async calls have cancellation and isolation implications. swift-concurrency covers them. | | "I know how actors work" | Actor reentrancy and isolation rules changed in Swift 6.2. swift-concurrency is current. | | "I'll fix the Sendable warnings later" | Sendable violations cause runtime crashes. swift-concurrency fixes them correctly now. | | "Combine is dead, just use async/await" | Combine has no deprecation notice. Rewriting working pipelines wastes time and introduces bugs. combine-patterns covers incremental migration. |
Swift 6 Concurrency (swift-concurrency):
Swift Performance (swift-performance):
User: "I'm getting 'data race' errors in Swift 6"
→ Invoke: /skill axiom-swift-concurrency
User: "How do I use @MainActor correctly?"
→ Invoke: /skill axiom-swift-concurrency
User: "My app is slow due to unnecessary copying"
→ Invoke: /skill axiom-swift-performance
User: "Should I use async/await for this network call?"
→ Invoke: /skill axiom-swift-concurrency
User: "How do I use assumeIsolated?"
→ Invoke: /skill axiom-assume-isolated
User: "My delegate callback runs on main thread, how do I access MainActor state?"
→ Invoke: /skill axiom-assume-isolated
User: "Should I use Mutex or actor?"
→ Invoke: /skill axiom-synchronization
User: "What's the difference between os_unfair_lock and OSAllocatedUnfairLock?"
→ Invoke: /skill axiom-synchronization
User: "What does borrowing do in Swift?"
→ Invoke: /skill axiom-ownership-conventions
User: "How do I use ~Copyable types?"
→ Invoke: /skill axiom-ownership-conventions
User: "My async code is slow, how do I profile it?"
→ Invoke: /skill axiom-concurrency-profiling
User: "I think I have actor contention, how do I diagnose it?"
→ Invoke: /skill axiom-concurrency-profiling
User: "My Core Data saves lose data from background tasks"
→ Route to: ios-data router (Core Data threading is framework-specific)
User: "How do I create a TaskGroup?"
→ Invoke: /skill axiom-swift-concurrency-ref
User: "What's the AsyncStream API?"
→ Invoke: /skill axiom-swift-concurrency-ref
User: "How do I create a custom global actor?"
→ Invoke: /skill axiom-swift-concurrency-ref
User: "How do I convert a completion handler to async?"
→ Invoke: /skill axiom-swift-concurrency-ref
User: "What are the actor reentrancy rules?"
→ Invoke: /skill axiom-swift-concurrency-ref
User: "My Combine pipeline silently stopped producing values"
→ Invoke: /skill axiom-combine-patterns
User: "Should I use Combine or async/await for this data flow?"
→ Invoke: /skill axiom-combine-patterns
User: "How do I bridge a Combine publisher into async/await code?"
→ Invoke: /skill axiom-combine-patterns
User: "AnyCancellable is leaking memory"
→ Invoke: /skill axiom-combine-patterns
User: "Check my code for Swift 6 concurrency issues"
→ Invoke: concurrency-auditor agent
development
Use when building ANY watchOS app — app structure, independent apps, Watch Connectivity, Smart Stack widgets, complications, controls, RelevanceKit, background tasks, ClockKit migration.
development
Use when working with HealthKit, WorkoutKit, health data, workouts, or fitness features on iOS or watchOS. Covers permissions, queries, background delivery, custom workouts, multidevice coordination.
development
Use when building, fixing, or improving ANY SwiftUI UI — views, navigation, layout, animations, performance, architecture, gestures, debugging, iOS 26 features.
content-media
Use when working with camera, photos, audio, haptics, ShazamKit, or Now Playing. Covers AVCaptureSession, PHPicker, PhotosPicker, AVFoundation, Core Haptics, audio recognition, MediaPlayer, CarPlay, MusicKit.