# 贡献指南 感谢你能够看到这里,本项目非常欢迎你的贡献! ## 贡献方法 如果你有代码或文档想要贡献,需要先了解以下内容。 1. 你要贡献什么类型的代码?(新扩展、修复 Bug、安全问题、项目框架优化、文档) 2. 如果你贡献了新文件或新片段,你的代码是否经过 `php-cs-fixer` 和 `phpstan` 的检查? 3. 在贡献代码前是否充分阅读了 [开发指南](../develop/)? 如果你可以回答以上问题,并已经对代码做出了修改,可以及时在项目 GitHub 仓库发起 Pull Request。待代码审查完毕后,可根据建议修改代码,或直接合并到主分支。 ## 贡献类型 本项目主要用途是编译静态链接的 PHP 二进制,基于 `symfony/console` 编写了命令行处理功能。在开发之前,如果你对它不够熟悉, 可以先查看 [symfony/console 文档](https://symfony.com/doc/current/components/console.html)。 ### 安全问题 因为本项目基本上是属于本地运行的 PHP 项目,一般来说不会存在远程攻击行为。但如果你发现了此类问题,请**不要**在 GitHub 仓库提交 PR 或 Issue, 你需要通过 [邮件](mailto:admin@zhamao.me) 的方式联系项目维护者(crazywhalecc)。 ### 修复 Bug 修复 Bug 一般不涉及项目结构和框架的修改,所以如果你可以定位到错误代码并直接修复它,请直接提交 PR。 ### 新扩展 对于添加一个新扩展来说,你需要先了解一些本项目的基本结构,以及如何根据现有的逻辑添加新扩展。在本页的下一章节将会详细介绍。 总的来说,你需要: 1. 评估扩展是否可以内联编译到 PHP 中。 2. 评估扩展的依赖库(如果有)是否可以静态编译。 3. 写出扩展的依赖库在不同平台编译命令。 4. 验证扩展及其依赖库能否与现有扩展和依赖库兼容。 5. 验证扩展在 `cli`、`micro`、`fpm`、`embed` 几种 SAPI 中均正常工作。 6. 编写文档,加入你的扩展。 ### 项目框架优化 如果你已经熟悉 `symfony/console` 的工作原理,并同时要对项目的框架进行一些修改或优化,请先了解以下事情: 1. 加入扩展不属于项目框架优化,但如果你在加入新的扩展时发现不得不优化框架,则需先对框架本身进行修改,然后再加入扩展。 2. 对于一些大规模逻辑修改(例如涉及 LibraryBase、Extension 对象等的修改)时,建议先提交 Issue 或 Draft PR 进行讨论方案。 3. 项目早期为纯中文开发项目,代码中存在一部分中文的注释。国际化项目后你可以提交 PR 将这些注释翻译为英语。 4. 请不要在代码中提交包含较多无用的代码片段,例如大量未被使用的变量、方法、类、重复写了很多次的代码。