swift-style

Code style conventions for clean, readable Swift code.

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "swift-style" with this command: npx skills add johnrogers/claude-swift-engineering/johnrogers-claude-swift-engineering-swift-style

Swift Style Guide

Code style conventions for clean, readable Swift code.

Core Principles

Clarity > Brevity > Consistency

Code should compile without warnings.

Naming

  • UpperCamelCase — Types, protocols

  • lowerCamelCase — Everything else

  • Clarity at call site

  • No abbreviations except universal (URL, ID)

// Preferred let maximumWidgetCount = 100 func fetchUser(byID id: String) -> User

Golden Path

Left-hand margin is the happy path. Don't nest if statements.

// Preferred func process(value: Int?) throws -> Result { guard let value = value else { throw ProcessError.nilValue } guard value > 0 else { throw ProcessError.invalidValue } return compute(value) }

Code Organization

Use extensions and MARK comments:

class MyViewController: UIViewController { // Core implementation }

// MARK: - UITableViewDataSource extension MyViewController: UITableViewDataSource { }

Spacing

  • Braces open on same line, close on new line

  • One blank line between methods

  • Colon: no space before, one space after

Self

Avoid self unless required by compiler.

// Preferred func configure() { backgroundColor = .systemBackground }

Computed Properties

Omit get for read-only:

var diameter: Double { radius * 2 }

Closures

Trailing closure only for single closure parameter.

Type Inference

Let compiler infer when clear. For empty collections, use type annotation:

var names: [String] = []

Syntactic Sugar

// Preferred var items: [String] var cache: [String: Int] var name: String?

Access Control

  • private over fileprivate

  • Don't add internal (it's the default)

  • Access control as leading specifier

Memory Management

resource.request().onComplete { [weak self] response in guard let self else { return } self.updateModel(response) }

Comments

  • Explain why, not what

  • Use // or /// , avoid /* */

  • Keep up-to-date or delete

Constants

Use case-less enum for namespacing:

enum Math { static let pi = 3.14159 }

Common Mistakes

Abbreviations beyond URL, ID, UUID — Abbreviations like cfg , mgr , ctx , desc hurt readability. Spell them out: configuration , manager , context , description . The three exceptions are URL, ID, UUID.

Nested guard/if statements — Deep nesting makes code hard to follow. Use early returns and guards to keep the happy path left-aligned.

Inconsistent self usage — Either always omit self (preferred) or always use it. Mixing makes code scanning harder and confuses capture semantics.

Overly generic type names — Manager , Handler , Helper , Coordinator are too vague. Names should explain responsibility: PaymentProcessor , EventDispatcher , ImageCache , NavigationCoordinator .

Implied access control — Don't skip access control. Explicit private , public helps future maintainers understand module boundaries. internal is default, so omit it.

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Coding

Video Editing Ai Tool Free

Get edited MP4 videos ready to post, without touching a single slider. Upload your raw video clips (MP4, MOV, AVI, WebM, up to 500MB), say something like "tr...

Registry SourceRecently Updated
Coding

Auto Shorts

convert long-form video into vertical short clips with this skill. Works with MP4, MOV, AVI, WebM files up to 500MB. TikTok creators use it for generating sh...

Registry SourceRecently Updated
Coding

Clip Maker

create raw video footage into trimmed video clips with this skill. Works with MP4, MOV, AVI, WebM files up to 500MB. content creators use it for generating s...

Registry SourceRecently Updated
Coding

Generator Ab2n 0330

Get generated video clips ready to post, without touching a single slider. Upload your text prompts (MP4, MOV, AVI, WebM, up to 500MB), say something like "g...

Registry SourceRecently Updated