mirror of
https://github.com/affaan-m/everything-claude-code.git
synced 2026-03-30 13:43:26 +08:00
- AGENTS.md: universal cross-tool file read by Claude Code, Cursor, Codex, and OpenCode - .cursor/: 15 hook events via hooks.json, 16 hook scripts with DRY adapter pattern, 29 rules (9 common + 20 language-specific) with Cursor YAML frontmatter - .codex/: reference config.toml, Codex-specific AGENTS.md supplement, 10 skills ported to .agents/skills/ with openai.yaml metadata - .opencode/: 3 new tools (format-code, lint-check, git-summary), 3 new hooks (shell.env, experimental.session.compacting, permission.ask), expanded instructions, version bumped to 1.6.0 - README: fixed Cursor section, added Codex section, added cross-tool parity table - install.sh: now copies hooks.json + hooks/ for --target cursor
67 lines
1.5 KiB
Markdown
67 lines
1.5 KiB
Markdown
---
|
|
description: "Swift patterns extending common rules"
|
|
globs: ["**/*.swift", "**/Package.swift"]
|
|
alwaysApply: false
|
|
---
|
|
# Swift Patterns
|
|
|
|
> This file extends the common patterns rule with Swift specific content.
|
|
|
|
## Protocol-Oriented Design
|
|
|
|
Define small, focused protocols. Use protocol extensions for shared defaults:
|
|
|
|
```swift
|
|
protocol Repository: Sendable {
|
|
associatedtype Item: Identifiable & Sendable
|
|
func find(by id: Item.ID) async throws -> Item?
|
|
func save(_ item: Item) async throws
|
|
}
|
|
```
|
|
|
|
## Value Types
|
|
|
|
- Use structs for data transfer objects and models
|
|
- Use enums with associated values to model distinct states:
|
|
|
|
```swift
|
|
enum LoadState<T: Sendable>: Sendable {
|
|
case idle
|
|
case loading
|
|
case loaded(T)
|
|
case failed(Error)
|
|
}
|
|
```
|
|
|
|
## Actor Pattern
|
|
|
|
Use actors for shared mutable state instead of locks or dispatch queues:
|
|
|
|
```swift
|
|
actor Cache<Key: Hashable & Sendable, Value: Sendable> {
|
|
private var storage: [Key: Value] = [:]
|
|
|
|
func get(_ key: Key) -> Value? { storage[key] }
|
|
func set(_ key: Key, value: Value) { storage[key] = value }
|
|
}
|
|
```
|
|
|
|
## Dependency Injection
|
|
|
|
Inject protocols with default parameters -- production uses defaults, tests inject mocks:
|
|
|
|
```swift
|
|
struct UserService {
|
|
private let repository: any UserRepository
|
|
|
|
init(repository: any UserRepository = DefaultUserRepository()) {
|
|
self.repository = repository
|
|
}
|
|
}
|
|
```
|
|
|
|
## References
|
|
|
|
See skill: `swift-actor-persistence` for actor-based persistence patterns.
|
|
See skill: `swift-protocol-di-testing` for protocol-based DI and testing.
|