# Maintaining ## 项目管理 Davinci 项目通过 [Project](https://github.com/edp963/davinci/projects) 来管理开发计划和维护清单。 ### 开发计划 开发计划在 [Roadmap](https://github.com/edp963/davinci/projects/4) 中管理。Committers 可以在 `To do` 栏中自行添加功能卡片,当功能还在卡片阶段时,意味着此功能还在设计和讨论阶段,卡片中应当包含: - 功能描述标题 - 功能设计明细及原理 - 如果包含子功能项,请逐一列出 当功能经过设计和讨论阶段之后,可以将功能卡片转成 Issue,并打上相应的 Tags。如果有 Committers 计划开发实现它,请将 Issue 拖到 `In progress` 栏中,并添加自己到 Issue 的 Assignees 列表中。**请确保功能经过充分设计和讨论之后再开始开发,未经社区讨论过的功能 PR 不会被合并。** ### 维护清单 维护清单在 [Maintenance](https://github.com/edp963/davinci/projects/5) 中管理。Committers 可以在 To do 栏中自行添加 bug 或亟待修复的缺陷类 Issue。同样的,如果有 Committers 计划开发修复它,请将 Issue 拖到 `In progress` 栏中,并添加自己到 Issue 的 Assignees 列表中。 **为保证开发高效以及目标专注,建议每位 Committer 在所有 Project `In progress` 栏中的 Issue 不超过2个。** ## 版本发布周期及流程 当前阶段,如无特殊需求,每月发布一个 `minor` 版本,正式版本发布不遵循此规则 版本发布之前需要确认 - 所有功能可以正常运行 - 与此版本相关的 Issue 和 PR 已经被正确处理 编辑更新日志以及升级版本号 - 新建一个 PR 将 dev-0.3 分支合并到 master,所有发布操作需要在 master 分支上进行。**注意!不要使用 squash merge!防止提交信息丢失!** - 从 master 新建一个 release 分支用来做发布的修改(例如:git checkout -b release-beta.7) - 在 CHANGELOG.md 里添加发布日志,可以用 compare 功能找到当前和之前版本的区别,将有价值的改动如实反馈给用户 - 对用户使用上无感知的改动建议(文档修补、微小的样式优化、代码风格重构等等)不要提及,保持 changelog 的内容有效性 - 用面向开发者的角度和叙述方式撰写 changelog,不描述修复细节,描述问题和对开发者的影响 - 尽量给出原始的 PR 链接,社区提交的 PR 改动加上提交者的链接或 Issue 链接 - 如果不确定改动的真实目的,可以向提交者进行咨询 - push release 分支并发起 changelog 的 PR 请其他 Committee 成员进行 Review - PR 的内容里填上 changelog 内容,好处是版本 changelog 的 PR 会关联在各个 issue 中,很容易知道 Issue 在哪个版本被改了 正式发布 release - 更新日志的修改合并后,删除 release-x 分支,给当前 master 分支打上版本号 tag - 上传 release 包,发布 release note