symplify/coding-standard
最新稳定版本:13.0.0
Composer 安装命令:
composer require symplify/coding-standard
包简介
Set of Symplify rules for PHP_CodeSniffer and PHP CS Fixer.
README 文档
README
Coding standard rules for clean, consistent, and readable PHP code. No configuration needed—just install and let it handle the rest.
They run best with ECS.
Install
composer require symplify/coding-standard --dev composer require phpecs/phpecs --dev
- Register in ECS config:
# ecs.php use Symplify\EasyCodingStandard\Config\ECSConfig; use Symplify\EasyCodingStandard\ValueObject\Set\SetList; return ECSConfig::configure() ->withSets([SetList::SYMPLIFY]);
- And run:
# dry-run without changes vendor/bin/ecs # apply changes vendor/bin/ecs --fix
12 Rules to Keep Your Code Clean
ArrayListItemNewlineFixer
Indexed PHP array item has to have one line per item
-$value = ['simple' => 1, 'easy' => 2]; +$value = ['simple' => 1, +'easy' => 2];
ArrayOpenerAndCloserNewlineFixer
Indexed PHP array opener [ and closer ] must be on own line
-$items = [1 => 'Hey']; +$items = [ +1 => 'Hey' +];
BlankLineAfterStrictTypesFixer
Strict type declaration has to be followed by empty line
declare(strict_types=1);
+
namespace App;
LineLengthFixer
Array items, method parameters, method call arguments, new arguments should be on same/standalone line to fit line length.
🔧 configure it!
-function some($veryLong, $superLong, $oneMoreTime) -{ +function some( + $veryLong, + $superLong, + $oneMoreTime +) { } -function another( - $short, - $now -) { +function another($short, $now) { }
MethodChainingNewlineFixer
Each chain method call must be on own line
-$someClass->firstCall()->secondCall(); +$someClass->firstCall() +->secondCall();
ParamReturnAndVarTagMalformsFixer
Fixes @param, @return, @var and inline @var annotations broken formats
/** - * @param string + * @param string $name */ function getPerson($name) { }
RemovePropertyVariableNameDescriptionFixer
Remove docblock descriptions which duplicate their property name
/** - * @var string $name + * @var string */ private $name;
RemoveMethodNameDuplicateDescriptionFixer
Remove docblock descriptions which duplicate their method name
/**
- * Get name
*
* @return string
*/
function getName()
{
}
RemovePHPStormAnnotationFixer
Remove "Created by PhpStorm" annotations
-/** - * Created by PhpStorm. - * User: ... - * Date: 17/10/17 - * Time: 8:50 AM - */ class SomeClass { }
RemoveUselessDefaultCommentFixer
Remove useless PHPStorm-generated @todo comments, redundant "Class XY" or "gets service" comments etc.
-/** - * class SomeClass - */ class SomeClass { - /** - * SomeClass Constructor. - */ public function __construct() { - // TODO: Change the autogenerated stub - // TODO: Implement whatever() method. } }
SpaceAfterCommaHereNowDocFixer
Add space after nowdoc and heredoc keyword, to prevent bugs on PHP 7.2 and lower, see https://laravel-news.com/flexible-heredoc-and-nowdoc-coming-to-php-7-3
$values = [
<<<RECTIFY
Some content
-RECTIFY,
+RECTIFY
+,
1000
];
StandaloneLineConstructorParamFixer
Constructor param should be on a standalone line to ease git diffs on new dependency
final class PromotedProperties
{
- public function __construct(int $age, string $name)
- {
+ public function __construct(
+ int $age,
+ string $name
+ ) {
}
}
StandaloneLineInMultilineArrayFixer
Indexed arrays must have 1 item per line
-$friends = [1 => 'Peter', 2 => 'Paul']; +$friends = [ + 1 => 'Peter', + 2 => 'Paul' +];
StandaloneLinePromotedPropertyFixer
Promoted property should be on standalone line
final class PromotedProperties
{
- public function __construct(public int $age, private string $name)
- {
+ public function __construct(
+ public int $age,
+ private string $name
+ ) {
}
}
统计信息
- 总下载量: 7.7M
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 379
- 点击次数: 1
- 依赖项目数: 64
- 推荐数: 2
其他信息
- 授权协议: MIT
- 更新时间: 2015-12-30