Swift on Linux —— 使用包依赖工具

前言

不管你接不接受,反正 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 提供的依赖包工具目前还不完善,还有很地需要改进的地方,但是,一门成熟的语言,拥有依赖管理工具是非常重要的。
对于开发者来说,掌握依赖管理工具的使用也是迈向更高水平的第一步,现在的就可以使用依赖管理工具吧!

目录:http://www.jianshu.com/notebooks/2633832/latest

你可能感兴趣的:(Swift on Linux —— 使用包依赖工具)