plugins/swift-apple-expert/skills/solid-swift/SKILL.md
SOLID principles for Swift 6 and SwiftUI (iOS 26+). Files < 100 lines, protocols separated, @Observable, actors, Preview-driven development. Features Modular MANDATORY.
npx skillsauth add fusengine/agents solid-swiftInstall 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.
Before ANY implementation, use TeamCreate to spawn 3 agents:
Before writing ANY new code:
Core/Extensions/, Core/Utilities/, Core/Protocols/Core/ directly| Layer | Location | Max Lines |
|-------|----------|-----------|
| Views | Features/[Feature]/Views/ | 80 |
| ViewModels | Features/[Feature]/ViewModels/ | 100 |
| Services | Features/[Feature]/Services/ | 100 |
| Protocols | Features/[Feature]/Protocols/ | 30 |
| Shared | Core/{Models,Protocols,Services,Extensions,Utilities}/ | - |
NEVER use flat Sources/ structure - always Features/[Feature]/
| Rule | Value |
|------|-------|
| File limit | 100 lines (split at 90) |
| ViewModels | @MainActor @Observable |
| Protocols | Features/[Feature]/Protocols/ or Core/Protocols/ ONLY |
| Models | Sendable structs |
| Documentation | /// on all public APIs |
| Previews | Every View MUST have #Preview |
| Topic | Reference | When to consult | |-------|-----------|-----------------| | SOLID Overview | solid-principles.md | Quick reference all principles | | SRP | single-responsibility.md | Fat views/VMs, splitting files | | OCP | open-closed.md | Adding providers, extensibility | | LSP | liskov-substitution.md | Protocol contracts, testing | | ISP | interface-segregation.md | Fat protocols, splitting | | DIP | dependency-inversion.md | Injection, testing, mocking | | Concurrency | concurrency-patterns.md | Actors, @MainActor, Sendable | | Anti-Patterns | anti-patterns.md | Code smells detection |
| Template | When to use | |----------|-------------| | view.md | SwiftUI View with subviews and #Preview | | viewmodel.md | @Observable ViewModel with @MainActor | | service.md | API Service, Mock, Cache actor | | protocol.md | Service protocol, CQRS, Auth | | model.md | Model, DTO, Error, Enum |
| Anti-Pattern | Fix |
|--------------|-----|
| Files > 100 lines | Split at 90 |
| Protocols in impl files | Move to Protocols/ directory |
| ObservableObject | Use @Observable |
| Completion handlers | Use async/await |
| Missing #Preview | Add preview for every View |
| Non-Sendable in async | Use struct with let |
| Flat Sources/ structure | Use Features/[Feature]/ |
development
Use when optimizing entity-based / semantic SEO 2026. Covers entity maps, Google Knowledge Graph resolution, salience scoring, passage-level ranking, about/sameAs/knowsAbout schema, Cloud Natural Language API validation.
development
Use when running SEO, GEO, schema, Core Web Vitals, sitemap, hreflang, E-E-A-T, AI Overviews, technical SEO, or structured data tasks. Covers full-site audits, single-page analysis, schema markup, content quality, AI search optimization, local SEO, sitemap/robots, internal linking, semantic clustering, and search experience.
development
Use when optimizing search experience (SXO). Covers intent matching, user personas, user stories, page-type analysis, dwell time, scroll depth, pogo-sticking prevention.
development
Use when optimizing local SEO. Covers Google Business Profile, NAP consistency, citations, reviews acquisition, Local Pack ranking, location pages, LocalBusiness schema.