Swift 5.3 路线图
作者 | Nicole Jacque
来源 | Swift Blog
这篇文章出自 Swift 官方博客,描述了 Swift 5.3 的目标,发布进程和预计时间表。
动机和目标
Swift 5.3 的目标依旧是继续提升质量的增强性能。此外,这个版本还将扩展支持 Swift 的平台的数量,特别是增加对 Windows 和其他 Linux 发行版的支持。
Swift 5.3的快照
Swift 5.3 的 release 分支的可下载快照将作为持续集成测试的一部分定期发布。同时尽可能为新支持的平台添加快照下载。
Swift 5.3 发布后,除了快照外,还将提供正式版本的下载。
将变更纳入 Swift 5.3
2020 年 4 月 20 日,我们将从 Swift 代码库和大多数相关的项目库中签出 release/5.3
分支。请留意新的分支命名方案。这个分支包含那些将在 Swift 5.3 中发布的变更。在签出分支后,如果变更符合发布标准,则可以通过 pull request 将变更放到这个分支上。
一些项目将在不同日期签出其 Swift 5.3 分支:
这些项目也将采取相同的策略:签出分支后,如果变更符合发布标准,则可以通过 pull request 将变更放到新分支上。
将变更引入 Swift 5.3 的策略
• Swift 5.3 的所有语言和 API 的变更都将通过 Swift Evolution 流程进行。Evolution 提案应该在分支建立日期之前完成,以增加其加入 Swift 5.3 版本的机会。将根据具体情况考虑一些例外情况,尤其是如果它们与发行版的核心目标相关时。
• 将根据风险和影响接受其他变更(例如错误修复,诊断改进,SourceKit 接口改进)。
• 如果低风险测试调整有助于提升发布的资量,则也可以在发布分支后期被接受。
• 随着版本的收敛,可接受的变更的标准将变得越来越严格。
受影响的代码库
以下代码库将有 release/5.3
分支,以作为Swift 5.3发行版的一部分:
• indexstore-db
• sourcekit-lsp
• swift
• swift-cmark
• swift-corelibs-foundation
• swift-corelibs-libdispatch
• swift-corelibs-xctest
• swift-integration-tests
• swift-llbuild
• swift-package-manager
• swift-stress-tester
• swift-syntax
• swift-tools-support-core
• swift-xcode-playground-support
llvm-project
也将有一个相应的 swift/release/5.3
分支。
为 release 分支提 Pull request
在新建 release 分支(release/5.3)后,如果希望一个 pull request 被列入这个 release 分支,则必须包含以下信息:
• 说明:对已解决的问题或增强的功能的描述。可以很简短,但应该描述清楚。
• 范围:对变更的影响/重要性的评估。例如,变更是否是对现有代码有破坏性,等等。
• SR(Swift Report)问题:指明是否变更解决/实现了 bug.swift.org
的问题/增强。
• 风险:此变更对发布产生的(特定)风险是什么?
• 测试:已经进行或需要进行哪些具体测试以进一步验证此变更的影响?
• 审阅者:受影响组件的一个或多个代码所有者需要审阅相应的变更。可以由代码所有者委托进行技术审查,或者以其他适当或有用的方式请求进行技术审查。
在 release/5.3
分支上进行的所有变更都必须经过相应的发布管理人员处理。