Agent Skills: Swift Error Handling

Standards for throwing functions, Result type, and Never. Use when implementing Swift error throwing, designing error hierarchies, using Result types, or adding do-catch blocks. (triggers: **/*.swift, throws, try, catch, Result, Error)

UncategorizedID: hoangnguyen0403/agent-skills-standard/swift-error-handling

Install this agent skill to your local

pnpm dlx add-skill https://github.com/HoangNguyen0403/agent-skills-standard/tree/HEAD/skills/swift/swift-error-handling

Skill Files

Browse the full folder contents for swift-error-handling.

Download Skill

Loading file tree…

skills/swift/swift-error-handling/SKILL.md

Skill Metadata

Name
swift-error-handling
Description
"Standards for throwing functions, Result type, and Never. Use when implementing Swift error throwing, designing error hierarchies, using Result types, or adding do-catch blocks. (triggers: **/*.swift, throws, try, catch, Result, Error)"

Swift Error Handling

Priority: P0

Workflow: Add Error Handling to a Swift Function

  1. Define a custom error enum conforming to Error
  2. Mark the function throws (or async throws)
  3. Use do-catch at the call site with specific catch clauses
  4. Map domain errors to user-facing messages at the presentation layer

Implementation Guidelines

Throwing Functions

  • Propagate Errors: Use throws for recoverable errors and async throws for modern concurrency.
  • Do-Catch: Handle errors close to source with specific catch clauses for each error type. Catch-all catch should be the last resort.
  • Error Types: Define custom errors as enums conforming to Error:

See implementation examples for custom error enums, do-catch patterns, and Result type usage.

  • Optional Try: Use try? only for non-critical errors where nil is acceptable.

Result Type

  • Async Alternatives: Use throws for synchronous code. Use Result for callbacks and non-async deferred error states.
  • Transformations: Use .map(), .flatMap() for functional composition.
  • Conversion: Use .get() to convert Result to throwing for use in try-catch.

Never Type & Preconditions

  • Fatalisms: Use Never return type only for unrecoverable crash scenarios or to indicate unreachable code. Never for expected errors.
  • Preconditions: Use precondition(), assert(), and fatalError() for programmer errors. Use assertionFailure() for debug-only checks.

Anti-Patterns

  • No try!: Use try? or do-catch.
  • No try? without nil check: Handle or log.
  • No Error(message): Use typed errors.

References