仿照喵神寫的的清理未使用圖片的工具, 里面有很詳細(xì)的注釋介紹
自己寫的命令行打包工具 歡迎star
本文通過(guò)對(duì)學(xué)習(xí)喵神寫蜂鳥項(xiàng)目所做的記錄
任務(wù): 清除xcode中未使用的圖片
步驟:
- 在所有搜索文件(swift, m, mm, xib, storyboard, etc)中尋找字符串 (并去除圖片后綴和擴(kuò)展名)
- 在文件夾中尋找所有圖片資源(png, jpg, imageset, etc), 獲取文件名和對(duì)應(yīng)路徑
- 從所有圖片資源(2)中將所用到的資源字符串(1)過(guò)濾掉, 剩下的就是沒有使用的圖片
- 刪除(3)中剩下的圖片
首先創(chuàng)建一個(gè)項(xiàng)目的空的文件夾
xcode 8以上自帶package manager
, 我們可以用項(xiàng)目的空目錄下使用命令swift package init
創(chuàng)建, 我們可以給這個(gè)工程加一個(gè)type
, 默認(rèn)的type
是Library
, 就是別人可以使用的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!
以后每次寫完一段代碼想要執(zhí)行, 都要重新執(zhí)行swift build
進(jìn)行編譯才可以執(zhí)行最新的代碼
三. 生成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="" 的形式找出圖片, 如下圖格式
b. 在代碼中我們一般使用 UIImage(named: ""), 只需要在.m或.mm中查找即可
五. 如何找到我們輸入的參數(shù):
我們輸入的參數(shù)都在CommandLine.arguments
中, 例如在main.swift中print(CommandLine.arguments)
執(zhí)行swift build
進(jìn)行編譯, 然后執(zhí)行編譯后的文件, 獲取參數(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ù)
引入后執(zhí)行swift build
編譯一下, 而且swift package generate-xcodeproj
只生效一次, 如果改動(dòng)了xcode的設(shè)置或者一些依賴什么的, 也需要執(zhí)行以下swift package generate-xcodeproj
這個(gè)命令
然后我們會(huì)發(fā)現(xiàn)項(xiàng)目中多了一個(gè)第三方的target
如果遇到一些第三方框架有些報(bào)錯(cuò)或問(wèn)題, 可以使用下面的方法:
swift build --clean
相當(dāng)于xcode的清理, 然后在執(zhí)行swift bulid
七: 寫代碼, 獲取用戶輸入的參數(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í)行:
在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)
例如下圖:
然后我們?cè)陧?xiàng)目目錄下執(zhí)行swift build
然后我們?cè)?code>Package.swift中指定targets
設(shè)置依賴關(guān)系
設(shè)置完依賴關(guān)系后執(zhí)行swift package generate-xcodeproj
, 我們會(huì)發(fā)現(xiàn)主程序依賴了GYReduceKit
這個(gè)framework
這時(shí)候在GYReduceTool
這個(gè)主程序的文件夾下的所有文件都可以import GYReduceKit
, 并使用這個(gè)庫(kù)的方法
關(guān)于測(cè)試:
寫好了測(cè)試的代碼, 可以點(diǎn)擊左邊的按鈕進(jìn)行測(cè)試, 也可以在項(xiàng)目目錄下輸入命令行命令: swift test