2020-03-10 14:14:15 +08:00
# 贡献
2020-06-11 15:32:54 +08:00
**感谢你来到这里和你对 mirai 做的所有贡献。**
2020-03-10 14:14:15 +08:00
mirai 欢迎一切形式的代码贡献。你可以通过以下几种途径向 mirai 贡献。
## 主仓库 `mirai-core`
2020-08-22 13:06:01 +08:00
### 构建
2021-01-28 09:32:23 +08:00
mirai git 仓库含有 submodule, 请在 clone 时使用 `--recursive` 参数, 或在 clone 后使用如下命令更新 submodule:
```shell script
git submodule init
git submodule update
```
2021-03-20 00:08:56 +08:00
项目首次初始化和构建可能要花费较长时间。
2020-08-22 13:06:01 +08:00
- 要构建项目, 请运行 `gradlew assemble`
- 要运行测试, 请运行 `gradlew test`
- 要构建项目并运行测试, 请运行 `gradlew build`
- 若要添加一个 suspend 函数, 请务必考虑 Java 兼容性, 使用 [kotlin-jvm-blocking-bridge ](https://github.com/mamoe/kotlin-jvm-blocking-bridge/blob/master/README-chs.md )
2020-12-31 21:00:43 +08:00
### 分支
2020-09-23 09:49:49 +08:00
2021-01-12 16:22:22 +08:00
- `1.x` : 1.x 版本的开发 (已停止)
- `dev` : 2.0 版本的开发
- `-release` 后缀: 基于[版本规范](docs/Evolution.md#版本规范), 用于从 `dev` 中筛选 bugfix 并发布一个版本的 patch 的版本. 如 `2.0-release` 会包含 `2.0.x` 版本的更新.
2020-09-23 09:49:49 +08:00
2020-12-31 21:00:43 +08:00
**请基于 `dev` 分支进行修改**
### 能做什么?
2020-05-24 18:25:36 +08:00
2021-03-20 00:08:56 +08:00
- 维护社区: 可以为 [mirai-console ](https://github.com/mamoe/mirai-console ) 编写插件, 并发布到论坛
2021-01-12 16:22:22 +08:00
2021-03-20 00:08:56 +08:00
- 代码优化: 优化任何功能设计或实现, 或是引入一个新的设计
2021-01-12 16:22:22 +08:00
- 解决问题: 在 [issues ](https://github.com/mamoe/mirai/issues ) 查看 mirai 正遇到的所有问题, 或在 [里程碑 ](https://github.com/mamoe/mirai/milestones ) 查看版本计划. 所有没有 assignee 的 issue 都处于
- 协议支持: [添加新协议支持 ](#添加协议支持 )
2021-06-25 18:01:19 +08:00
### 加入开发组
你可以随时提交 PR 解决任何问题。而若有兴趣,我们也欢迎你加入开发组,请联系 support@mamoe.net
[mirai-compose]: https://github.com/sonder-joker/mirai-compose
[plugin-center 服务端]: https://github.com/project-mirai/mirai-plugin-center
[mirai-api-http]: https://github.com/project-mirai/mirai-api-http
2021-06-26 20:11:55 +08:00
[project-mirai/docs]: https://github.com/project-mirai/docs
[docs.mirai.mamoe.net]: https://docs.mirai.mamoe.net
2021-06-25 18:01:19 +08:00
| 名称 | 描述 |
|:------------------------:|:------------------------------------------------------------------------------------------------------:|
| core 和 console 日常更新 | 在 milestone 安排的日常更新。我们目前版本速度是一个月到两个月发布一个次版本( 2.x)。需要日常的开发。 |
| console 后端 | 架构稳定,现在格外需要在易用性上的提升,首先需要一个优化方案,再实现它们。 |
| console 文档 | 根据用户反馈,现在文档十分缺少。需要以用户的身份体验过 console 的人编写用户文档。 |
| 图形前端 [mirai-compose] | 各功能都缺目前尤其缺少对接 console PluginConfig 的图形化配置的实现。 |
| [plugin-center 服务端] | 插件中心正在建设中。后端 Spring, 前端 Vuetify。由于开发人员学业繁忙, 暂搁置。 |
| plugin-center 社区 | 插件中心计划支持所有语言的插件,因此需要与社区 SDK 作者沟通并帮助它们接入 Console 的 PluginLoader API 和插件中心的要求。 |
| plugin-center console 端 | 需要评估现在 console 架构是否足够支持插件中心及所有语言插件的管理,实现与插件中心的对接。 |
| plugin-center gradle | 对接插件中心,实现通过 Task 上传插件。还没有开始做。 |
| mirai-console-loader | console 启动器。对接插件中心的 API, 支持下载和更新插件等。不确定之后是否会有人实现。 |
| IDE 插件 | IntelliJ IDEA 的插件的工作。可以为 mirai 框架添加检查等功能。这个部分目前基本满足需求。 |
| [mirai-api-http] v2 | 日常维护。 |
2021-06-26 20:11:55 +08:00
| [project-mirai/docs] | 用户友好文档自动部署,使用 VuePress , 部署于 [docs.mirai.mamoe.net],目前还有部分超链接错误的问题。 |
2021-06-25 18:01:19 +08:00
2021-01-12 16:22:22 +08:00
### 里程碑
[里程碑 ](https://github.com/mamoe/mirai/milestones ) 为各版本的开发计划. 在完成所有任务后就会发布该版本.
`Backlog` 为没有设定目标版本的计划. 如果有相关 PR, 这些计划就可能会被确定到一个最近的版本.
### 添加协议支持
请查看 [PacketFactory.kt ](mirai-core/src/commonMain/kotlin/network/protocol/packet/PacketFactory.kt ) 了解网络层架构.
参考现有的 `PacketFactory` 实现和一些有关协议的 PR (带有 `protocol` 标签) 了解如何添加新的 `PacketFactory` .
2021-03-20 00:08:56 +08:00
### 开发 mirai-core
2020-03-10 14:14:15 +08:00
2021-03-20 00:08:56 +08:00
- 使用 IntelliJ IDEA 或 Android Studio
- 安装 IDE 插件 [kotlin-jvm-blocking-bridge ](https://github.com/Him188/kotlin-jvm-blocking-bridge/blob/master/README-chs.md#%E5%AE%89%E8%A3%85-intellij-idea-%E6%88%96-android-studio-%E6%8F%92%E4%BB%B6 )
- 在 mirai-core 和 mirai-core-api 使用纯 Kotlin 实现
2020-03-10 14:14:15 +08:00
- 尽量不要引用新的库
2020-06-11 15:32:54 +08:00
- 遵守 Kotlin 官方代码规范(提交前使用 IDE 格式化代码 (commit 时勾选 'Reformat code'))
2021-03-28 00:29:38 +08:00
- 保证二进制兼容性: 在提交前执行 `gradlew build` , 若有不兼容变更会得到错误。
如果你正在添加一个新功能,可以忽略这个错误,执行 `gradlew clean apiDump` 。这将会生成 `binary-compatibility-validator.api` ,文件的变化反映了你的修改情况。将这些文件一并提交。 (详细了解 [Kotlin/binary-compatibility-validator ](https://github.com/Kotlin/binary-compatibility-validator ))
2021-03-20 00:08:56 +08:00
- 通过 GitHub 的 Pull Request 提交代码,很快就会有相关模块负责人员来审核
如果你不太保证自己能达到上述要求也没关系, mirai 感谢你的每一行代码,维护者会审核代码并尽可能帮助你。