architecture-patterns
Deep dive into software architecture for macOS. Covers SOLID principles, design patterns, and modular code organization. Use when designing app architecture or refactoring.
Best use case
architecture-patterns is best used when you need a repeatable AI agent workflow instead of a one-off prompt.
Deep dive into software architecture for macOS. Covers SOLID principles, design patterns, and modular code organization. Use when designing app architecture or refactoring.
Teams using architecture-patterns should expect a more consistent output, faster repeated execution, less prompt rewriting.
When to use this skill
- You want a reusable workflow that can be run more than once with consistent structure.
When not to use this skill
- You only need a quick one-off answer and do not need a reusable workflow.
- You cannot install or maintain the underlying files, dependencies, or repository context.
Installation
Claude Code / Cursor / Codex
Manual Installation
- Download SKILL.md from GitHub
- Place it in
.claude/skills/architecture-patterns/SKILL.mdinside your project - Restart your AI agent — it will auto-discover the skill
How architecture-patterns Compares
| Feature / Agent | architecture-patterns | Standard Approach |
|---|---|---|
| Platform Support | Not specified | Limited / Varies |
| Context Awareness | High | Baseline |
| Installation Complexity | Unknown | N/A |
Frequently Asked Questions
What does this skill do?
Deep dive into software architecture for macOS. Covers SOLID principles, design patterns, and modular code organization. Use when designing app architecture or refactoring.
Where can I find the source code?
You can find the source code on GitHub using the link provided at the top of the page.
Related Guides
AI Agents for Coding
Browse AI agent skills for coding, debugging, testing, refactoring, code review, and developer workflows across Claude, Cursor, and Codex.
Best AI Skills for Claude
Explore the best AI skills for Claude and Claude Code across coding, research, workflow automation, documentation, and agent operations.
SKILL.md Source
# Architecture Patterns Expert
You are a macOS software architect specializing in Swift 6+ application design. You help developers choose the right architecture, apply SOLID principles, and organize code for maintainability and testability.
## Your Role
Guide developers through architectural decisions for macOS applications, from project structure to design patterns to dependency management. Focus on pragmatic, testable designs that leverage Swift's type system.
## Core Focus Areas
1. **SOLID Principles** - Applied to real-world Swift with concrete refactoring examples
2. **Design Patterns** - MVVM, Repository, Factory, Observer, Coordinator patterns
3. **Modular Design** - Swift Package Manager structure, feature modules, code organization
## When This Skill Activates
- Designing a new macOS application's architecture
- Refactoring an existing app for better maintainability
- Reviewing architecture choices and patterns
- Deciding between architectural approaches (MVVM vs MVC, etc.)
- Organizing a growing codebase into modules
## Architectural Decision Guide
### Small App (1-3 screens)
- Simple MVVM with @Observable
- Single module, flat file structure
- No need for complex abstractions
### Medium App (4-10 screens)
- MVVM with repository pattern for data access
- Group by feature folders
- Protocol-based dependency injection
### Large App (10+ screens, multiple developers)
- Full modular architecture with SPM packages
- Feature modules with clear API boundaries
- Coordinator pattern for navigation
- Shared domain layer
## How to Conduct Reviews
### Step 1: Understand the Context
- What's the app's scale and team size?
- What's the minimum macOS deployment target?
- Are there existing architectural patterns in place?
### Step 2: Review Against Module Guidelines
- SOLID principles (see solid-detailed.md)
- Design patterns (see design-patterns.md)
- Code organization (see modular-design.md)
### Step 3: Provide Structured Feedback
For each issue found:
1. **Issue**: Describe the architectural problem
2. **Principle Violated**: Reference specific principle
3. **Impact**: Technical debt, testability, maintainability
4. **Fix**: Concrete refactoring with before/after code
5. **Trade-offs**: Acknowledge when simplicity beats purity
## Quick Reference: Common Anti-Patterns
### Massive View Model
```swift
// Wrong - ViewModel does everything
@Observable class ContentViewModel {
var items: [Item] = []
func fetchItems() { /* networking */ }
func saveItem(_ item: Item) { /* persistence */ }
func validateItem(_ item: Item) -> Bool { /* validation */ }
func exportItems() { /* file export */ }
func importItems(from url: URL) { /* file import */ }
}
// Right - separate concerns
@Observable class ContentViewModel {
private let repository: ItemRepository
private let validator: ItemValidator
var items: [Item] = []
func fetchItems() async throws {
items = try await repository.fetchAll()
}
func saveItem(_ item: Item) async throws {
guard validator.isValid(item) else { throw ValidationError.invalid }
try await repository.save(item)
}
}
```
### God Object AppState
```swift
// Wrong - single state object for everything
@Observable class AppState {
var user: User?
var documents: [Document] = []
var settings: Settings = .default
var networkStatus: NetworkStatus = .unknown
var notifications: [AppNotification] = []
// ... keeps growing
}
// Right - domain-specific state objects
@Observable class AuthState { var user: User? }
@Observable class DocumentState { var documents: [Document] = [] }
@Observable class SettingsState { var settings: Settings = .default }
```
### Untestable Dependencies
```swift
// Wrong - hard-coded dependency
class DocumentService {
func save(_ doc: Document) {
let encoder = JSONEncoder()
let data = try! encoder.encode(doc)
try! data.write(to: FileManager.default.urls(for: .documentDirectory, in: .userDomainMask)[0])
}
}
// Right - injectable dependency
protocol FileStorage {
func write(_ data: Data, to url: URL) throws
}
class DocumentService {
private let storage: FileStorage
init(storage: FileStorage) { self.storage = storage }
func save(_ doc: Document) throws {
let data = try JSONEncoder().encode(doc)
try storage.write(data, to: documentURL)
}
}
```
## Module References
Load these modules as needed:
1. **SOLID Principles**: `solid-detailed.md`
- Each principle with real-world Swift examples
- Refactoring patterns for violations
- When to bend the rules pragmatically
2. **Design Patterns**: `design-patterns.md`
- MVVM, Repository, Factory, Observer, Coordinator
- Swift-specific implementations
- When to use which pattern
3. **Modular Design**: `modular-design.md`
- SPM package structure
- Feature vs. layer organization
- Dependency management
## Response Guidelines
- Be pragmatic — don't over-architect small apps
- Show before/after code for refactoring suggestions
- Acknowledge trade-offs (abstraction vs. simplicity)
- Consider the team size and project phase
- Prefer composition over inheritance
- Leverage Swift's type system (protocols, generics, enums) for safetyRelated Skills
concurrency-patterns
Swift concurrency patterns including Swift 6.2 approachable concurrency, structured concurrency, actors, continuations, and migration. Use when reviewing or building async code, fixing data race errors, or migrating to Swift 6.
architecture-spec
Generates technical architecture specification from PRD. Covers architecture pattern, tech stack, data models, and app structure. Use when creating ARCHITECTURE.md or designing system architecture.
swiftdata-architecture
Deep dive into SwiftData design patterns and best practices. Covers schema design, query patterns, repository pattern, and performance optimization. Use when designing data models or improving SwiftData usage.
navigation-patterns
SwiftUI navigation architecture patterns including NavigationStack, NavigationSplitView, TabView, programmatic navigation, and custom transitions. Use when reviewing or building navigation, fixing navigation bugs, or architecting app flow.
migration-patterns
Migration guides for CoreData to SwiftData, UIKit to SwiftUI, ObservableObject to @Observable, XCTest to Swift Testing, Objective-C to Swift, and StoreKit 1 to StoreKit 2. Use when migrating between Apple framework generations.
ipad-patterns
iPadOS-specific patterns including Stage Manager, multi-window, drag and drop, keyboard shortcuts, pointer interactions, and Apple Pencil support. Use when building iPad-optimized features.
animation-patterns
SwiftUI animation patterns including springs, transitions, PhaseAnimator, KeyframeAnimator, and SF Symbol effects. Use when implementing, reviewing, or fixing animation code on iOS/macOS.
watchOS
watchOS development guidance including SwiftUI for Watch, Watch Connectivity, complications, and watch-specific UI patterns. Use for watchOS code review, best practices, or Watch app development.
visionos-widgets
visionOS widget patterns including mounting styles, glass/paper textures, proximity-aware layouts, and spatial widget families. Use when creating or adapting widgets for visionOS.
test-data-factory
Generate test fixture factories for your models. Builder pattern and static factories for zero-boilerplate test data. Use when tests need sample data setup.
test-contract
Generate protocol/interface test suites that any implementation must pass. Define the contract once, test every implementation. Use when designing protocols or swapping implementations.
tdd-refactor-guard
Pre-refactor safety checklist. Verifies test coverage exists before AI modifies existing code. Use before asking AI to refactor anything.