前言
不管你接不接受,反正 Swift 官方出了一个包依赖工具,它就原生的集成在 Swift Toolchain 里面,你安装了 Swift 到 Linux 上的时候,就已经拥有了一个包依赖的工具。
Swift 包依赖工具和 Carthage 工作原理类似,都是去中心化的包管理系统,它要求开发者提供依赖包的 Git 地址。
使用他人提供的包
当你需要使用一个他人提供的 Swift 包时,需要知道他的 Git 地址,这里有一个现成的 Demo 包,是我写的。
https://github.com/PonyCui/swift-demo-student
这时候,还记得每个工程下面都有一个 Package.swift 文件吗?
编辑它,改成以下内容:
import PackageDescription
let package = Package(
dependencies: [
.Package(url: "https://github.com/PonyCui/swift-demo-student.git", majorVersion: 1)
]
)
上述代码的意思是,帮我从 https://github.com/PonyCui/swift-demo-student.git 上拷贝代码回来,我要的版本是 1.x.x 。
接下来,回到命令行执行 swift build,如果出现以下提示,那么你就成功导入了一个包。你会看到根目录下出现一个叫 Packages 的文件夹,它就导进来的包。
如果失败了?翻墙试试?
Compiling Swift Module 'Student' (1 sources)
Linking Library: .build/debug/Student.a
剩下的事情,就是尽情地使用这个包,只需要 import 包名称,即可使用。
import Student
let student = Student(name:"Pony", age: 8)
print(student.mySchool())
更新包
包的作者一般都会定时维护这些包的代码,当包在Git上存在更新时,如果本地已经存在 Packages 文件夹,那 swift build 不会自动更新包文件。
要更新本地的包文件,你需要把 Packages 文件夹删除,然后再次执行 swift build 命令。
制作一个包
要制作一个包,你必须将代码放到 Git 上,不管这是私有的 Git 还是公有的 Git。
创建一个工程, Sources文件夹下存放所有源码,在需要公开给他人的成员变量和方法前添加 public 关键字。
// 这是一个例子
public struct Student {
public let name: String
public let age: Int
public init(name: String, age: Int) {
self.name = name
self.age = age
}
public func mySchool() -> String {
if age < 12 {
return "Primary School"
}
else {
return "Other School"
}
}
}
修改 Package.swift 文件
//把 name 改成你想要的
import PackageDescription
let package = Package(
name: "Student"
)
然后,为 Git 库打一个 tag,tag 的名称就是版本号,比如 1.0.0 。
最后,提交所有修改到远端,就可以了。
包可以依赖包,依赖包也可以继续依赖包,以此,构建一个依赖链。
结语
Swift 提供的依赖包工具目前还不完善,还有很地需要改进的地方,但是,一门成熟的语言,拥有依赖管理工具是非常重要的。
对于开发者来说,掌握依赖管理工具的使用也是迈向更高水平的第一步,现在的就可以使用依赖管理工具吧!