shawnveltman / phpcsfixer-helper
Collection of my PHP CS Fixer rules to make it easy to share between projects
Requires
- php: ^7.4|^8.0
Requires (Dev)
- orchestra/testbench: ^6.0
- phpunit/phpunit: ^9.0
This package is auto-updated.
Last update: 2025-01-03 16:52:33 UTC
README
This allows our team to share the same code styling, to reduce the amount of time we need to discuss those things, as well as sorting through changes between commits that are only formating related.
Prerequisites
If you don't already have PhpCsFixer and Husky installed, then copy & paste below into terminal:
composer require friendsofphp/php-cs-fixer --dev npm i -D husky lint-staged@^11.x.x npm install --save-dev @shufo/prettier-plugin-blade prettier npx husky init
Then, update the .husky/pre-commit file to only have this line:
npx lint-staged
Then, add this line to package.json (this assumes your Php CS Fixer file is called .php-cs-fixer.php, change as needed):
"lint-staged": { "*.php": "php ./vendor/bin/php-cs-fixer fix --config .php-cs-fixer.php", "*.blade.php": "node_modules/.bin/prettier --write resources/**/*.blade.php" },
Installation
You can install the package via composer:
composer require shawnveltman/phpcsfixer-helper --dev
Once you've installed it, create a new file called .php-cs-fixer.php in your base directory.
Update .gitignore
Add .php-cs-fixer.cache to your .gitignore file!
Usage
After installing the package, navigate to your PHP CS Fixer file (ie .php-cs-fixer.php), and replace the existing $rules array with:
use Shawnveltman\PhpcsfixerHelper\PhpcsfixerHelper; $helper = new PhpcsfixerHelper(); $rules = $helper->get_style_rules();
Fixer File
If you don't have a fixer file, you can use the template below to your .php-cs-fixer.php file:
<?php use PhpCsFixer\Finder; use Shawnveltman\PhpcsfixerHelper\PhpcsfixerHelper; $helper = new PhpcsfixerHelper(); $rules = $helper->get_style_rules(); $finder = Finder::create() ->notPath('bootstrap') ->notPath('storage') ->notPath('vendor') ->notPath('coverage-report') ->in(getcwd()) ->name('*.php') ->notName('*.blade.php') ->notName('index.php') ->notName('server.php') ->ignoreDotFiles(true) ->ignoreVCS(true); $config = new PhpCsFixer\Config(); return $config->setFinder($finder) ->setRules($rules) ->setRiskyAllowed(true) ->setUsingCache(true);
Testing
composer test
Common Issues / Troubleshooting
If you run the above steps and it is not automatically running on commit, there may be different npm versions at play in your team.
Step 1 is to delete your node_modules directory, and package-lock.json files, and then run npm install.
Step 2 is to ensure all team members are using the same version of npm.
Changelog
Please see CHANGELOG for more information what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email shawn.veltman@gmail.com instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.
Laravel Package Boilerplate
This package was generated using the Laravel Package Boilerplate.