Skip to content

vknabel/vscode-swiftlint

Repository files navigation

SwiftLint for VS Code

VS Code extension to enforce Swift style and conventions via SwiftLint. You can use SwiftLint installed globally or via the Swift Package Manager.

Global Installation

You can install SwiftLint globally using Homebrew or Mint. For a local setup you can use the Swift Package Manager.

# Using Homebrew
$ brew install swiftlint
# Using Mint
$ mint install realm/SwiftLint
# Manually
$ git clone https://github.com/realm/SwiftLint.git
$ swift build -c release

Local Installation

Add the package to your dependencies in Package.swift:

// swift-tools-version:4.2

import PackageDescription

let package = Package(
    name: "Komondor",
    products: [ ... ],
    dependencies: [
        // My dependencies
        .package(url: "https://github.com/orta/PackageConfig.git", from: "0.0.1"),
        // Dev deps
        .package(url: "https://github.com/orta/Komondor.git", from: "0.0.1"),
+        .package(url: "https://github.com/realm/SwiftLint.git", from: "0.58.2"),
    ],
    targets: [...]
)

Configuration

Config Type Default Description
swiftlint.enable Bool true Whether SwiftLint should actually do something.
swiftlint.onlyEnableOnSwiftPMProjects Bool false Requires and uses a SwiftLint as SwiftPM dependency. This will cause the extension to build the Swift package upon first launch.
swiftlint.onlyEnableWithConfig Bool false Only lint if config present. Requires swiftlint.configSearchPaths.
swiftlint.path String swiftlint The location of the globally installed SwiftLint (resolved with the current path if only a filename).
swiftlint.additionalParameters [String] [] Additional parameters to pass to SwiftLint.
swiftlint.configSearchPaths [String] [] Possible paths for SwiftLint config. This disables nested configurations!
swiftlint.autoLintWorkspace Bool true Automatically lint the whole project right after start.

Note that when swiftlint.onlyEnableOnSwiftPMProjects is enabled, the extension will only run swiftlint executables built as part of the Swift package open in the workspace. It will try to build the binary once on first launch. If the build fails, the extension will not fall back to a globally installed swiftlint. If you prefer a locally built swiftlint, but want to skip the automatic initial build, let swiftlint.path point to the local executable you have built manually or by other means independent of the extension.

Commands

Short Title Command
SwiftLint: Lint workspace swiftlint.lintWorkspace
SwiftLint: Fix workspace swiftlint.fixWorkspace
SwiftLint: Fix document swiftlint.fixDocument
SwiftLint: Fix all known issues source.fixAll.swiftlint

To automatically fix all issues within a document on save, add the following to your .vscode/settings.json:

{
  "editor.codeActionsOnSave": {
    "source.fixAll": true
  }
}

License

vscode-swiftlint is available under the MIT license.