* misc: fixup count of patch * ci: update ncipollo/release-action to 1.16.0 * docs: update CONTRIBUTING.md * docs: update CONTRIBUTING files * docs: update CONTRIBUTING files * Update CONTRIBUTING.md * docs: sync zh_cn's update to en * docs: correct grammar errors * docs: fixup jdk version to 21 --------- Co-authored-by: xiaoxijun <A3167717663@hotmail.com>
3.3 KiB
3.3 KiB
为Luminol贡献代码
English | 中文
我们很开心您想为我们的项目做出贡献!一般来说,我们对PR的审核是十分宽松的; 但是如果您可以遵守下列的规则,我们可以更快地完成审核。
使用个人账户进行 Fork
我们会定期尝试合并已有的 PR,如果有一些小问题,会尝试帮您解决这些问题。
但是如果您使用了组织账号进行 PR,我们就不能对您的 PR 进行修改了。因此我们只能关闭你的PR然后进行手动合并。
所以,请不要使用组织账号进行 Fork!
您可以看看 这个 Issue 来了解一下我们为什么无法修改组织账号的 PR。
开发环境
在开始开发之前,您首先需要拥有以下软件作为开发环境:
gitJDK 21 或更高版本
了解补丁(Patches)
Luminol 使用和 Folia 一样的补丁系统,并为了针对不同部分的修改分成了两个目录:
luminol-api- 对Folia-API/Paper-API/Spigot-API/Bukkit进行的修改。luminol-server- 对 Minecraft 标准服务器原有逻辑进行的修改。
补丁系统是基于 git 的,你可以在这里了解 git 的基本内容: https://git-scm.com/docs/gittutorial
如果你已经 Fork 了主储存库,那么下面你应该这么做:
- 将你的仓库 clone 到本地;
- 在你的 IDE 或 终端 内执行 Gradle 的
applyAllPatches任务,如果是在终端内,你可以执行./gradlew applyAllPatches; - 进入 仓库根目录下的
luminol-api和luminol-server文件夹进行修改。
顺便一提,仓库根目录下的 luminol-api 和 luminol-server 并不是正常的 git 仓库:
- 在应用补丁前,基点将会指向未被更改的源码
- 在基点后的每一个提交都是一个补丁
- 只有在 Folia 最后一个提交后的提交才会被视为 luminol 补丁
增加补丁
按照以下步骤增加一个补丁是非常简单的:
- 对
luminol-api和luminol-server进行修改; - 使用 git 添加你的修改,比如
git add .(不要提交新建的文件的修改); - 使用
git commit -m <提交信息>进行提交; - 运行 Gradle 任务
rebuildAllServerPatches将你的提交转化为一个补丁; - 运行 Gradle 任务
fixupPaperApiFilePatches生成新建文件的补丁文件(注意不要提交); - 将你生成的补丁文件进行推送。
这样做以后,你就可以将你的补丁文件进行 PR 提交。
修改补丁
你可以使用以下方法来修改一个补丁的内容:
- 在 HEAD 上直接进行修改;
- 使用
git commit -a --fixup <hash>来进行一个更正提交;(不要提交对在luminol新建文件的修改)- 如果你想要更改提交信息,你也可以用
--squash来代替--fixup。
- 如果你想要更改提交信息,你也可以用
- 使用
git rebase -i --autosquash base来进行自动变基,你只需要输入:q来关闭确认页面即可; - 运行 Gradle 任务
rebuildAllServerPatches来修改已被修改的补丁; - 运行 Gradle 任务
fixupPaperApiFilePatches来修改已被修改的在luminol新建文件的补丁(注意不要提交); - 将修改后的补丁 PR 发回储存库。