Swift代码自动格式化--SwiftFormat安装与使用

一、为什么要使用SwiftFormat

我们在作为Git预提交代码之前对其格式进行自动化,确保代码规范,有助于提高code review的效率,对比了几款针对Swift代码的自动格式化,发现SwiftFormat超越了您对代码格式化程序的期望。除了调整空格之外,它还可以插入或删除implicit self,删除多余的括号,并纠正许多其他与标准Swift习惯用法的偏差。


二、如何安装SwiftFormat

我们可以直接用 Homebrew 来安装它,已经安装的同学可以忽略这一步:

brew install swiftformat
安装 SwiftFormatXcode插件:
  • 打开终端输入brew install --cask swiftformat-for-xcode,如【终端.jpg】图标1处,出现2表示安装成功;
  • 然后执行open "/Applications/SwiftFormat For Xcode.app" ,如3
    终端.jpg

打开 SwiftFormat For Xcode.app 后,会自动安装到Xcode上,需要重启Xcode才能生效。重新打开Xcode,在 XcodeEditor目录下能看到 SwiftFormat 菜单就说明插件安装成功了。

image.png

注意:你可以会遇到打开Xcode没看到SwiftFormat
  • 这个时候注意一下SwiftFormat -> about中的提示:How do I install it?
    image.jpg
  • 打开系统偏好设置,点开扩展勾选上Xcode Source Editor,再重启Xcode就可以看到了。
    image.jpg

操作到这里,我们的代码就可以用SwiftFormat -> Formar File菜单来对其进行格式化了。但是每次手动并不是我们想要的最终方案,我们希望操作可以再简化点:保存代码的同时就自动对代码进行格式化~~~


三、使用 Automator 添加自动化脚本

Automator是一款系统软件,中文名是自动操作。文件路径:启动台 -> 其他,你也可以全局搜索来找到。

image.png

1、打开Automator,选择快速操作(Quick Action):

image.png

2、在搜索栏搜索Script,双击 选择 运行 AppleScript
image.png

3、用下面的脚本代码替换上图中的脚本:

on run {input, parameters}
    tell application "System Events"
        tell process "Xcode"
            set frontmost to true
            if menu item "Format File" of menu of menu item "SwiftFormat" of menu "Editor" of menu bar 1 exists then
                click menu item "Format File" of menu of menu item "SwiftFormat" of menu "Editor" of menu bar 1
            end if
            click menu item "Save" of menu "File" of menu bar 1
        end tell
    end tell
    return input
end run

该脚本将执行以下操作:

  • 检查XcodeEditor菜单下是否存在SwiftFormat -> Format File菜单项;
  • 如果存在,则自动触发 Format File菜单点击,来格式化代码;
  • 最后,自动点击 Save 菜单,保存文件修改。

4、点击Build按钮,里面的代码会自动高亮:

image.png

5、接着修改 【工作流程收到】 这一项配置为【 没有输入】,【位于】改成 Xcode.app。
image.png

6、最后⌘ + S保存,将该自动操作命名为 XcodeFormatAndSave,它会自动保存在 ~/Library/Services/ 目录下。重新打开Xcode,我们将在 Xcode -> Services 菜单下看到它,但是目前它还是不能工作的,还需要进一步配置。

image.png

四、添加键盘快捷键

我们最终的目标是要在保存文件(⌘ + S)的时候,自动进行代码格式化。

打开 系统偏好设置 -> 键盘 -> 快捷键,选择 左侧 App快捷键 这一项,添加一个新的快捷键,应用程序选择 Xcdoe,菜单标题和刚才保存的自动操作名称一样:XcodeFormatAndSave,键盘快捷键设置成 ⌘ + S,然后点击 添加 按钮。

image.png

最后,我们还需要为它配置运行权限,不然会报错。

打开 系统偏好设置 -> 安全性与隐私 -> 隐私,在左侧列表中选择 辅助功能,授予 Xcode控制权限。

image.png

到这里,我们在Xcode中保存(⌘ + SSwift文件的时候,就会自动触发代码格式化了,非常nice ~~~


参考 Xcode Format and Save using SwiftFormat and Automator

你可能感兴趣的:(Swift代码自动格式化--SwiftFormat安装与使用)