1.3 KiB
1.3 KiB
| paths | ||
|---|---|---|
|
Swift Coding Style
This file extends common/coding-style.md with Swift specific content.
Formatting
- SwiftFormat for auto-formatting, SwiftLint for style enforcement
swift-formatis bundled with Xcode 16+ as an alternative
Immutability
- Prefer
letovervar— define everything asletand only change tovarif the compiler requires it - Use
structwith value semantics by default; useclassonly when identity or reference semantics are needed
Naming
Follow Apple API Design Guidelines:
- Clarity at the point of use — omit needless words
- Name methods and properties for their roles, not their types
- Use
static letfor constants over global constants
Error Handling
Use typed throws (Swift 6+) and pattern matching:
func load(id: String) throws(LoadError) -> Item {
guard let data = try? read(from: path) else {
throw .fileNotFound(id)
}
return try decode(data)
}
Concurrency
Enable Swift 6 strict concurrency checking. Prefer:
Sendablevalue types for data crossing isolation boundaries- Actors for shared mutable state
- Structured concurrency (
async let,TaskGroup) over unstructuredTask {}