swift 開(kāi)發(fā)命令行工具

仿照喵神寫(xiě)的的清理未使用圖片的工具, 里面有很詳細(xì)的注釋介紹
自己寫(xiě)的命令行打包工具 歡迎star

本文通過(guò)對(duì)學(xué)習(xí)喵神寫(xiě)蜂鳥(niǎo)項(xiàng)目所做的記錄
任務(wù): 清除xcode中未使用的圖片
步驟:

  1. 在所有搜索文件(swift, m, mm, xib, storyboard, etc)中尋找字符串 (并去除圖片后綴和擴(kuò)展名)
  2. 在文件夾中尋找所有圖片資源(png, jpg, imageset, etc), 獲取文件名和對(duì)應(yīng)路徑
  3. 從所有圖片資源(2)中將所用到的資源字符串(1)過(guò)濾掉, 剩下的就是沒(méi)有使用的圖片
  4. 刪除(3)中剩下的圖片

首先創(chuàng)建一個(gè)項(xiàng)目的空的文件夾
xcode 8以上自帶package manager, 我們可以用項(xiàng)目的空目錄下使用命令swift package init創(chuàng)建, 我們可以給這個(gè)工程加一個(gè)type, 默認(rèn)的typeLibrary, 就是別人可以使用的framework. 這里我們創(chuàng)建的是一個(gè)可執(zhí)行文件, 使用命令swift package init --type executable
執(zhí)行結(jié)果:

 gaoyu@localhost  ~/Desktop/repo/GYReduceTool  swift package init --type executable
Creating executable package: GYReduceTool
Creating Package.swift 
Creating Sources/
Creating Sources/main.swift
Creating Tests/

Package.swift 文件: 負(fù)責(zé)解析這個(gè)項(xiàng)目的一些依賴和項(xiàng)目名字
Sources/ : 我們的代碼一般在該文件夾下

一. 先來(lái)看 Package.swift 中的代碼:

import PackageDescription

let package = Package(
    name: "GYReduceTool"
)

Package這個(gè)struct是在 PackageDescription中來(lái)的, 這個(gè)文件是用來(lái)讓package manager知道你的package是什么, 安裝或?qū)ふ移渌膒ackage的時(shí)候, package manager會(huì)在項(xiàng)目的倉(cāng)庫(kù)里尋找Package.swift文件, 并且執(zhí)行這個(gè)文件, 提取出以package為名字的變量,然后進(jìn)行安裝

二. main.swift

這個(gè)文件是可執(zhí)行文件的入口, 如果我們想要編譯這個(gè)文件, 我們需要在命令行中執(zhí)行swift build, 則編譯以后的文件在當(dāng)前文件夾下的./.build/debug/GYReduceTool中, 想要運(yùn)行這個(gè)編譯后的文件我們只需要執(zhí)行命令: 就會(huì)執(zhí)行里面的代碼輸出hello world!
以后每次寫(xiě)完一段代碼想要執(zhí)行, 都要重新執(zhí)行swift build進(jìn)行編譯才可以執(zhí)行最新的代碼

運(yùn)行可執(zhí)行文件

目錄結(jié)構(gòu)

三. 生成xcodeproj

我們可以使用swift package --help來(lái)查看一些命令, 通過(guò)查看, 我們可以看到 swift package manager 給我們提供了一個(gè)命令: swift package generate-xcodeproj 用來(lái)在當(dāng)前目錄創(chuàng)建一個(gè)`xcodeproj

幫助命令

四. 確定輸入的參數(shù)設(shè)置

搜索不用的圖片的資源我們想要的參數(shù):
--project 確定在哪個(gè)文件夾下進(jìn)行搜索 路徑
--resource-extensions 想要搜索什么樣的文件 后綴名 png jpg imageset gif jpeg
--file-extensions 我們?cè)谑裁礃拥奈募锶ニ阉?例如 .m .mm .swift 文件

a. xib, storyboard中所使用的圖片都是以XML文本的形式存在
所有只要查找 image name="" 的形式找出圖片, 如下圖格式

xib, storyboard中的圖片

b. 在代碼中我們一般使用 UIImage(named: ""), 只需要在.m或.mm中查找即可

五. 如何找到我們輸入的參數(shù):

我們輸入的參數(shù)都在CommandLine.arguments中, 例如在main.swift中print(CommandLine.arguments)
執(zhí)行swift build進(jìn)行編譯, 然后執(zhí)行編譯后的文件, 獲取參數(shù)

獲取參數(shù)

可以看到上圖中的 兩個(gè)參數(shù) gao yu就打印出來(lái)了
我們?cè)诖a中可以通過(guò)循環(huán)遍歷出參數(shù), 但是很麻煩, 這種事情應(yīng)該用一個(gè)輪子來(lái)做: 這時(shí)候我們應(yīng)該引入第三方庫(kù)

for argu in CommandLine.arguments {
    
}

六: 如何在在package中引入第三方庫(kù)

引入第三方庫(kù)

引入后執(zhí)行swift build編譯一下, 而且swift package generate-xcodeproj只生效一次, 如果改動(dòng)了xcode的設(shè)置或者一些依賴什么的, 也需要執(zhí)行以下swift package generate-xcodeproj這個(gè)命令

示例1

然后我們會(huì)發(fā)現(xiàn)項(xiàng)目中多了一個(gè)第三方的target

示例2

如果遇到一些第三方框架有些報(bào)錯(cuò)或問(wèn)題, 可以使用下面的方法:
swift build --clean 相當(dāng)于xcode的清理, 然后在執(zhí)行swift bulid

七: 寫(xiě)代碼, 獲取用戶輸入的參數(shù)

import Foundation
import CommandLineKit


let cli = CommandLineKit.CommandLine()

/// shortFlag: "p":  表示 -p     longFlag: "project":  表示 --project   required: false  是否為必須的參數(shù)
let projectOption = StringOption(shortFlag: "p",
                                 longFlag: "project",
                                 helpMessage: "Path to the project.")

// MultiStringOption 字符串?dāng)?shù)組
let resourceExtensionsOption = MultiStringOption(shortFlag: "r",
                                          longFlag: "resource-extensions",
                                          helpMessage: "Extensions to search.")

let fileExtensionsOption = MultiStringOption(shortFlag: "f",
                                                 longFlag: "file-extensions",
                                                 helpMessage: "File Extensions to search.")


let help = BoolOption(shortFlag: "h", longFlag: "help",
                      helpMessage: "Prints a help message.")


cli.addOptions(projectOption, resourceExtensionsOption, fileExtensionsOption, help)

do {
    try cli.parse()
} catch {
    cli.printUsage(error)
    exit(EX_USAGE)
}

print(projectOption.value)

執(zhí)行:


執(zhí)行

在swift package manager中會(huì)在Sources文件夾下尋找, 如有有文件main, 他就會(huì)認(rèn)為這個(gè)文件是一個(gè)可執(zhí)行文件, 把它打成一個(gè)可執(zhí)行文件,
package manager在組織編譯項(xiàng)目的時(shí)候使用各個(gè)文件夾來(lái)區(qū)分各個(gè)target
比如我在 Sources 文件夾下, 創(chuàng)建一個(gè)文件夾aaa, aaa文件夾下有main.swift, 則aaa就會(huì)被編譯成一個(gè)可執(zhí)行文件, 項(xiàng)目中只有一個(gè)main
如果我在Sources文件夾下, 創(chuàng)建一個(gè)文件夾bbb, 項(xiàng)目b中就不可以再有main了, 但是這個(gè)文件夾會(huì)被當(dāng)成Library(庫(kù))來(lái)處理, 就會(huì)編譯成framework, 這時(shí)候, 我們只要在項(xiàng)目中鏈接這個(gè)framework, 就可以使用了, 但是我們鏈接以后, 再執(zhí)行swift package generate-xcodeproj, 這個(gè)鏈接就會(huì)壞掉, 這個(gè)命令是單向的 , 所以最好再Package.swift中把這個(gè)framework指定出來(lái)

例如下圖:

Sources目錄

然后我們?cè)陧?xiàng)目目錄下執(zhí)行swift build

build效果

然后我們?cè)?code>Package.swift中指定targets設(shè)置依賴關(guān)系

Package.swift

設(shè)置完依賴關(guān)系后執(zhí)行swift package generate-xcodeproj, 我們會(huì)發(fā)現(xiàn)主程序依賴了GYReduceKit這個(gè)framework

依賴 GYReduceKit

這時(shí)候在GYReduceTool這個(gè)主程序的文件夾下的所有文件都可以import GYReduceKit, 并使用這個(gè)庫(kù)的方法

關(guān)于測(cè)試:

測(cè)試示例

寫(xiě)好了測(cè)試的代碼, 可以點(diǎn)擊左邊的按鈕進(jìn)行測(cè)試, 也可以在項(xiàng)目目錄下輸入命令行命令: swift test

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容