No puede seleccionar más de 25 temas Los temas deben comenzar con una letra o número, pueden incluir guiones ('-') y pueden tener hasta 35 caracteres de largo.

CONTRIBUTING.md 4.3 KiB

hace 4 años
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. 如何贡献我的源代码
  2. ===
  3. 此文档介绍了 ThinkPHP 团队的组成以及运转机制,您提交的代码将给 ThinkPHP 项目带来什么好处,以及如何才能加入我们的行列。
  4. ## 通过 Github 贡献代码
  5. ThinkPHP 目前使用 Git 来控制程序版本,如果你想为 ThinkPHP 贡献源代码,请先大致了解 Git 的使用方法。我们目前把项目托管在 GitHub 上,任何 GitHub 用户都可以向我们贡献代码。
  6. 参与的方式很简单,`fork`一份 ThinkPHP 的代码到你的仓库中,修改后提交,并向我们发起`pull request`申请,我们会及时对代码进行审查并处理你的申请。审查通过后,你的代码将被`merge`进我们的仓库中,这样你就会自动出现在贡献者名单里了,非常方便。
  7. 我们希望你贡献的代码符合:
  8. * ThinkPHP 的编码规范
  9. * 适当的注释,能让其他人读懂
  10. * 遵循 Apache2 开源协议
  11. **如果想要了解更多细节或有任何疑问,请继续阅读下面的内容**
  12. ### 注意事项
  13. * 本项目代码格式化标准选用 [**PSR-2**](http://www.kancloud.cn/thinkphp/php-fig-psr/3141);
  14. * 类名和类文件名遵循 [**PSR-4**](http://www.kancloud.cn/thinkphp/php-fig-psr/3144);
  15. * 对于 Issues 的处理,请使用诸如 `fix #xxx(Issue ID)` 的 commit title 直接关闭 issue。
  16. * 系统会自动在 PHP 5.4 5.5 5.6 7.0 和 HHVM 上测试修改,其中 HHVM 下的测试容许报错,请确保你的修改符合 PHP 5.4 ~ 5.6 和 PHP 7.0 的语法规范;
  17. * 管理员不会合并造成 CI faild 的修改,若出现 CI faild 请检查自己的源代码或修改相应的[单元测试文件](tests);
  18. ## GitHub Issue
  19. GitHub 提供了 Issue 功能,该功能可以用于:
  20. * 提出 bug
  21. * 提出功能改进
  22. * 反馈使用体验
  23. 该功能不应该用于:
  24. * 提出修改意见(涉及代码署名和修订追溯问题)
  25. * 不友善的言论
  26. ## 快速修改
  27. **GitHub 提供了快速编辑文件的功能**
  28. 1. 登录 GitHub 帐号;
  29. 2. 浏览项目文件,找到要进行修改的文件;
  30. 3. 点击右上角铅笔图标进行修改;
  31. 4. 填写 `Commit changes` 相关内容(Title 必填);
  32. 5. 提交修改,等待 CI 验证和管理员合并。
  33. **若您需要一次提交大量修改,请继续阅读下面的内容**
  34. ## 完整流程
  35. 1. `fork`本项目;
  36. 2. 克隆(`clone`)你 `fork` 的项目到本地;
  37. 3. 新建分支(`branch`)并检出(`checkout`)新分支;
  38. 4. 添加本项目到你的本地 git 仓库作为上游(`upstream`);
  39. 5. 进行修改,若你的修改包含方法或函数的增减,请记得修改[单元测试文件](tests);
  40. 6. 变基(衍合 `rebase`)你的分支到上游 master 分支;
  41. 7. `push` 你的本地仓库到 GitHub;
  42. 8. 提交 `pull request`;
  43. 9. 等待 CI 验证(若不通过则重复 5~7,不需要重新提交 `pull request`,GitHub 会自动更新你的 `pull request`);
  44. 10. 等待管理员处理,并及时 `rebase` 你的分支到上游 master 分支(若上游 master 分支有修改)。
  45. *若有必要,可以 `git push -f` 强行推送 rebase 后的分支到自己的 `fork`*
  46. *绝对不可以使用 `git push -f` 强行推送修改到上游*
  47. ### 注意事项
  48. * 若对上述流程有任何不清楚的地方,请查阅 GIT 教程,如 [这个](http://backlogtool.com/git-guide/cn/);
  49. * 对于代码**不同方面**的修改,请在自己 `fork` 的项目中**创建不同的分支**(原因参见`完整流程`第9条备注部分);
  50. * 变基及交互式变基操作参见 [Git 交互式变基](http://pakchoi.me/2015/03/17/git-interactive-rebase/)
  51. ## 推荐资源
  52. ### 开发环境
  53. * XAMPP for Windows 5.5.x
  54. * WampServer (for Windows)
  55. * upupw Apache PHP5.4 ( for Windows)
  56. 或自行安装
  57. - Apache / Nginx
  58. - PHP 5.4 ~ 5.6
  59. - MySQL / MariaDB
  60. *Windows 用户推荐添加 PHP bin 目录到 PATH,方便使用 composer*
  61. *Linux 用户自行配置环境, Mac 用户推荐使用内置 Apache 配合 Homebrew 安装 PHP 和 MariaDB*
  62. ### 编辑器
  63. Sublime Text 3 + phpfmt 插件
  64. phpfmt 插件参数
  65. ```json
  66. {
  67. "autocomplete": true,
  68. "enable_auto_align": true,
  69. "format_on_save": true,
  70. "indent_with_space": true,
  71. "psr1_naming": false,
  72. "psr2": true,
  73. "version": 4
  74. }
  75. ```
  76. 或其他 编辑器 / IDE 配合 PSR2 自动格式化工具
  77. ### Git GUI
  78. * SourceTree
  79. * GitHub Desktop
  80. 或其他 Git 图形界面客户端