对于多人协作的项目,如果没有强制性的代码风格约束,很容易出现不一致问题。
我们需要有规范来告诉别人应该怎么去做,但是我们无法保证每个人都是在按照规范来做。
标准规范都应该落实到强制性约束上,这可以让开发者无需考虑规范,但又始终在规范之内.
这里我不得不赞一下golang语言,存在相应的工具,你无需纠结于缩进使用空格还是TAB,
gofmt来解决, import的顺序是如何,也有goimports的工具.
之前一直也想着整理PHP代码规范,然后落实到项目中去,但没有具体落实下去。留下来
的技术债,终究是要还的。最近项目集成了gitlab-ci,
可以在提交代码的时候在代码检查,正好符合强制性约束的要求。
一开始使用的是PHP_Code_Sniffer来做代码检查,但是因为一些历史原因,不能很好的适配,如果忽略warning级别的提示,检查的力度又太粗了。于是换了php-cs-fixer, 对里面的一些配置项做了筛选,确定了最终的配置。
配置文件如下:
1 |
|
主要效果:
- 去掉无用
use - 使用
use时去掉开始的\, 如use \ApiTester;=>use ApiTester; - 一个
class文件中的use语句按照字母序排序 else if变成单个elseif- 去掉无用的
else - 不使用
array(), 使用[] =>,+,-,.,?操作符两侧各保留一个空格return语句前保留一个空行- 不使用函数的别名,如使用
implode(), 而不是join() - 函数之间以单个空行分隔
- 纯字符串使用单引号,不使用双引号
- 使用
new Object();而不是new Object;
- 使用
- 注释不以
.结尾 - 注释缩进
在CI中检测上一次的commit:
1 | git diff --name-only --diff-filter=ACMRT --exit-code HEAD~1 |
通过先fix:
1 | php ci/php-cs-fixer.phar fix --config=.php_cs $file |
然后比较改动:
1 | git diff --exit-code --color=always $file |
来确定文件是否符合规范并输出不同