Most formatting-related guidelines are enforced by SwiftLint using our documented configuration file. Xcode’s default behaviors and preferences are preferred for considerations not covered by SwiftLint rules.
-
Resolve any added SwiftLint warnings prior to opening a pull request with your changes.
-
In the rare case in which you need to opt out of a SwiftLint rule, use swiftlint:disable:this on the lines that require the exception, along with a comment explaining the exception(s).
-
Use Xcode’s default indentation preferences (spaces, not tabs, with a tab width of four spaces).
-
Use Xcode’s Re-Indent feature (Editor → Structure → Re-Indent, or
⌃I
) to ensure code and documentation is properly indented.- There are times in which Xcode indents something in an unfavorable way. These occurrences are fairly rare. Rather than fighting the tools, it is still preferred to use Xcode’s behavior in these cases. For example, when a function takes multiple closures as parameters and capture list is used at the callsite, the closure bodies indent differently from each other:
// Without capture list: updateFeedFromNetwork(networkCompletion: { result in // code… }, persistenceCompletion: { result in // code… }) // With capture list: updateFeedFromNetwork(networkCompletion: { [weak self] result in // code… }, persistenceCompletion: { result in // code… })