Swift 5.0 发布流程

这篇文章描述了 Swift 5.0 的目标、发布流程和预计时间表。

动机和目标

Swift 5.0 的主要目标是使该语言实现 ABI 稳定性。这将使操作系统供应商能够部署稳定的 Swift 运行时,可供可执行文件和库链接。

与 ABI 稳定性相关,模块稳定性也将是主要的焦点。这将会在 Swift 5.0 版本或后续的 5.x 版本中实现,具体取决于其准备情况。

二进制兼容性

Swift 5.0 与之前的 Swift 版本不二进制兼容。二进制兼容性允许由不同 Swift 编译器编译的 Swift 代码在运行时级别链接和互操作。

但是,未来的 Swift 版本将与 Swift 5 二进制兼容。

源代码兼容性

与 Swift 4.2 一样,绝大多数使用 Swift 4.2 编译器构建的源代码应该可以使用 Swift 5.0 编译器编译。

但是,Swift 5 编译器将不支持 Swift 3 兼容模式。Swift 4.2 是最后一个支持 Swift 3 模式的 Swift 版本。在 Swift 3 之后的版本中,语言表面和内部实现都有重要的更改,这将成为未来(和持久的)源代码和二进制稳定性的基础。

Swift 5.0 快照

Swift 5.0 发布分支的可下载快照将定期发布,作为持续集成测试的一部分。

一旦 Swift 5.0 发布,除了快照之外,还将发布官方最终构建版本。

将更改纳入 Swift 5.0

swift-5.0-branch 分支包含将在 Swift 5.0 中发布的更改。该分支的管理方式如下:

此计划的五个显著例外是 swift-package-managerswift-llbuildswift-corelibs-foundationswift-corelibs-xctestswift-corelibs-libdispatch,它们将每天从 master 主开发分支合并到 swift-5.0-branch 分支,并且其最终更改截止日期将延长至 11 月 16 日之后,具体时间将在稍后公布。

项目 截止日期
swift 2018 年 11 月 20 日
swift-package-manager 2019 年 2 月 11 日
swift-llbuild 2019 年 2 月 11 日

将更改纳入 Swift 5.0 的理念

受影响的存储库

以下存储库将具有 swift-5.0-branch 分支,以跟踪作为 Swift 5.0 版本一部分的源代码

发布经理

发布的总体管理将由以下人员监督,他们将在 Swift 5.0 发布版本收敛时宣布何时对更改实施更严格的控制

如有关于发布管理流程的任何问题,请随时在开发论坛上发帖,或直接联系 Ted Kremenek

发布分支的拉取请求

为了使拉取请求在最终从 master 主开发分支重新分支后被考虑包含在发布分支中,它必须包含以下信息:

进入 swift-5.0-branch 分支的所有更改(自动从 master 主开发分支合并的更改除外)必须通过拉取请求,且拉取请求必须由相应的发布经理接受。