CONTRIBUTING-zh.md
Spring AI Alibaba 从开源建设以来,受到了很多社区同学的关注。社区的每一个 Issue ,每一个 PR,都是对整个项目的帮助,都在为建设更好用的 Spring AI 添砖加瓦。
我们真心地感谢为这个项目提出过 Issue 和 PR 的开发者。我们希望有更多社区的开发者加入进来,一起把项目做好。
在贡献代码之前,请您稍微花一些时间了解为 Spring AI Alibaba 贡献代码的流程。
我们随时都欢迎任何贡献,无论是简单的错别字修正,BUG 修复还是增加新功能。请踊跃提出问题或发起 PR。我们同样重视文档以及与其它开源项目的整合,欢迎在这方面做出贡献。
如果是一个比较复杂的修改,建议先在 Issue 中添加一个 Feature 标识,并简单描述一下设计和修改点。
如果您是初次贡献,可以先从 good first issue 和 help wanted 中认领一个比较简单的任务。
Fork 图标 将 alibaba/spring-ai-alibaba fork 到自己的空间。chickenlj,那就是执行 git clone https://github.com/chickenlj/spring-ai-alibaba.git 进行 clone 操作。git config --list ,查看 git 的全局用户名和邮箱。fork 出来的代码后,原仓库 main 分支可能出现了新的提交,这时候为了避免提交的 PR 和 Main 中的提交出现冲突,需要及时 merge main 分支。
git remote add upstream https://github.com/alibaba/spring-ai-alibaba 将原始仓库地址配置为 upstream。git fetch upstream 从 upstream 拉取更新。git checkout main 切换到 main 分支。git rebase upstream/main rebase 最新代码。Spring AI Alibaba 作为 Spring AI 的实现之一,在代码规范方面直接沿用了 Spring AI 项目规范,在正式开始之前请参考相关代码格式规范说明,提交代码前需要先配置好代码格式规范。
开发自己的功能,开发完毕后建议使用 mvn clean package 命令确保修改后的代码能在本地编译通过。执行该命令的同时还能以 spring 的方式自动格式化代码。然后再提交代码,提交代码之前请注意创建一个新的有关本特性的分支,用该分支进行代码提交。
本地开发完成后,强烈建议在提交 PR 之前执行项目tools\make提供的 make 命令进行本地持续集成(CI)检查,以确保代码符合项目的标准和规范。如果对于本地CI有任何疑问,可以在控制台输入 make help 了解具体信息。
为了减少一些不必要的代码风格问题,Spring AI Alibaba 提供了本地 Checkstyle 检查功能。可以在项目根目录下执行 mvn checkstyle:check 命令来检查代码风格是否符合规范。
为了确保代码的整洁,请删除 Java 文件中未使用的导入。可以通过执行 mvn spotless:apply 命令来自动删除未使用的导入。
在编码完成之后,需要基于 pr 规范[lint-pr-title.yml](.github/workflows/lint-pr-title.yml)对提交信息进行 format & check,确保提交信息符合规范。
Commit 规范: git commit -m "类型(模块): 空格 符合规范的提交信息",例如 feat(docs): contribute-zh 更新
提交 PR,根据 Pull request template 写明修改点和实现的功能,等待 code review 和 合并,成为 Spring AI Alibaba Contributor,为更好用的 Spring AI Alibaba 做出贡献。