A tool to automatically fix PHP Coding Standards issues https://cs.symfony.com/

HypeMC 3b471b4337 bug: PhpdocAlignFixer - fix static `@method` (#6366) 2 лет назад
.github 8b569d38f9 `ISSUE_TEMPLATE` hints to check applied rules (#6398) 2 лет назад
dev-tools 277c55acdd DX: Fix CI static analysis workflow (#6506) 2 лет назад
doc d5ad795316 feature: Introduce configurability to PhpdocOrderFixer (#6466) 2 лет назад
docker a855d14dc5 DX: Fix CI/CD issues (#6411) 2 лет назад
src 3b471b4337 bug: PhpdocAlignFixer - fix static `@method` (#6366) 2 лет назад
tests 3b471b4337 bug: PhpdocAlignFixer - fix static `@method` (#6366) 2 лет назад
.composer-require-checker.json 3bfe42676d Test on PHP 8.1 3 лет назад
.editorconfig fc50e3f3e0 DX: cleanup Github Actions configs 4 лет назад
.gitattributes ef752ba608 BlankLineBeforeStatementFixer - add "phpdoc" 3 лет назад
.gitignore fa62f33d6e DX: .gitignore ASC file 3 лет назад
.php-cs-fixer.dist.php 22d3cbfd0d Bump migration sets used to PHP7.4 3 лет назад
.php-cs-fixer.php-highest.php 22510eacd3 DX: format dot files 3 лет назад
.php-cs-fixer.php-lowest.php c619e16bdb Bump required PHP to 7.4 3 лет назад
.yamllint.yml 4543492603 Drop CircleCI and AppVeyor 4 лет назад
CHANGELOG.md 4465d70ba7 prepared the 3.9.5 release 2 лет назад
CONTRIBUTING.md 3adc81b7b0 DX: Add Docker dev setup 4 лет назад
LICENSE 61e14b592e bump year 3 лет назад
README.md d983f4bb16 Docs: update PhpStorm integration link 3 лет назад
UPGRADE-v3.md 195d1b3152 Update UPGRADE-v3.md with php_unit_test_annotation/case deprecation 3 лет назад
benchmark.sh ab538a47e7 DX: chmod +x for benchmark.sh file 3 лет назад
box.json.dist fb4d4e0f8a Fix file missing for php8 4 лет назад
ci-integration.sh c704d13f56 DX: new config filename 3 лет назад
composer.json b3cc7ef69f DX: no need to use forked diff anymore (#6526) 2 лет назад
docker-compose.override.yaml.dist c619e16bdb Bump required PHP to 7.4 3 лет назад
docker-compose.yaml c619e16bdb Bump required PHP to 7.4 3 лет назад
logo.md 61e14b592e bump year 3 лет назад
logo.png 1d01692483 Rework documentation 4 лет назад
php-cs-fixer c619e16bdb Bump required PHP to 7.4 3 лет назад
phpmd.xml d187410494 Do not allow assignments in if statements 4 лет назад
phpstan.neon 2389f5c408 minor: Let PhpdocLineSpan fixer detect docblocks when seperator from token with attribute (#6343) 2 лет назад
phpunit.xml.dist 10a23f8f85 bump as for code coverage more memory is needed 3 лет назад

README.md

PHP CS Fixer logo

PHP Coding Standards Fixer

The PHP Coding Standards Fixer (PHP CS Fixer) tool fixes your code to follow standards; whether you want to follow PHP coding standards as defined in the PSR-1, PSR-2, etc., or other community driven ones like the Symfony one. You can also define your (team's) style through configuration.

It can modernize your code (like converting the pow function to the ** operator on PHP 5.6) and (micro) optimize it.

If you are already using a linter to identify coding standards problems in your code, you know that fixing them by hand is tedious, especially on large projects. This tool does not only detect them, but also fixes them for you.

Documentation

Installation

The recommended way to install PHP CS Fixer is to use Composer in a dedicated composer.json file in your project, for example in the tools/php-cs-fixer directory:

$ mkdir --parents tools/php-cs-fixer
$ composer require --working-dir=tools/php-cs-fixer friendsofphp/php-cs-fixer

For more details and other installation methods, see installation instructions.

Usage

Assuming you installed PHP CS Fixer as instructed above, you can run the following command to fix the files PHP files in the src directory:

$ tools/php-cs-fixer/vendor/bin/php-cs-fixer fix src

See usage, list of built-in rules, list of rule sets and configuration file documentation for more details.

If you need to apply code styles that are not supported by the tool, you can create custom rules.

Editor Integration

Dedicated plugins exist for:

Community

The PHP CS Fixer is maintained on GitHub at https://github.com/FriendsOfPHP/PHP-CS-Fixer. Bug reports and ideas about new features are welcome there.

You can reach us at https://gitter.im/PHP-CS-Fixer/Lobby about the project, configuration, possible improvements, ideas and questions, please visit us!

Contribute

The tool comes with quite a few built-in fixers, but everyone is more than welcome to contribute more of them.