webservco / coding-standards
Custom, opinionated coding standards based on PSR12, SlevomatCodingStandard, and PHPCompatibility.
Installs: 2 230
Dependents: 45
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:phpcodesniffer-standard
pkg:composer/webservco/coding-standards
Requires
- php: ^8.4
Requires (Dev)
- pds/skeleton: ^1
- phan/phan: ^5
- php-parallel-lint/php-console-highlighter: ^1
- php-parallel-lint/php-parallel-lint: ^1
- phpcompatibility/php-compatibility: ^9
- phpmd/phpmd: ^2
- phpstan/phpstan: ^2
- phpstan/phpstan-deprecation-rules: ^2
- phpstan/phpstan-doctrine: ^2
- phpstan/phpstan-phpunit: ^2
- phpstan/phpstan-strict-rules: ^2
- phpstan/phpstan-symfony: ^2
- phpunit/phpunit: ^10
- psalm/plugin-symfony: ^5
- slevomat/coding-standard: ^8
- squizlabs/php_codesniffer: ^3
- vimeo/psalm: ^6
- weirdan/doctrine-psalm-plugin: ^2
README
A collection of coding standards and configuration files.
Custom, opinionated coding standards based on PSR12, SlevomatCodingStandard, and PHPCompatibility.
Setup
composer require --dev webservco/coding-standards
Optionally, install any of the dependencies from require-dev that you wish to use in your project.
Components
Phan
Usage:
vendor/bin/phan --config-file vendor/webservco/coding-standards/phan/config.php
PHP_CodeSniffer
Example configuration file .phpcs/php-coding-standard.xml, to be placed in own project:
<?xml version="1.0"?> <ruleset name="WebServCo-CodingStandard-PHP83"> <description>Custom, opinionated coding standards based on PSR12, SlevomatCodingStandard, and PHPCompatibility.</description> <rule ref="vendor/webservco/coding-standards/phpcs/ruleset-psr-php83-slevomat.xml"> <properties> <property name="rootNamespaces" type="array"> <element key="src/Project" value="Project" /> <element key="tests/unit" value="Tests" /> </property> </properties> </rule> </ruleset>
Usage:
vendor/bin/phpcs --standard=.phpcs/php-coding-standard.xml --extensions=php -sp bin config public resources src tests
Rulesets:
- phpcs/ruleset-namespaces.xml: Slevomat namespace usage;
- phpcs/ruleset-psr-php74-slevomat.xml: PHP 7.4, PSR-12, Slevomat;
- phpcs/ruleset-psr-php81.xml: PHP 8.1, PSR-12;
- phpcs/ruleset-psr-php81-slevomat.xml: PHP 8.1, PSR-12, Slevomat;
- phpcs/ruleset-psr-php82.xml: PHP 8.2, PSR-12;
- phpcs/ruleset-psr-php82-slevomat.xml: PHP 8.2, PSR-12, Slevomat;
- phpcs/ruleset-psr-php83.xml: PHP 8.3, PSR-12;
- phpcs/ruleset-psr-php83-slevomat.xml: PHP 8.3, PSR-12, Slevomat;
PHPMD
Usage:
vendor/bin/phpmd bin,config,public,resources,src,tests json vendor/webservco/coding-standards/phpmd/phpmd-rule-set.xml
PHPStan
Symfony support
- install symfony related packages:
- (if using Doctrine) "phpstan/phpstan-doctrine": "^1",
- "phpstan/phpstan-symfony": "^1",
 
- (if using Doctrine) create .phpstan/get_doctrine_manager.php, as in phpstan-doctrine documentation
- use specific phpstan-symfony.neonorphpstan-symfony-doctrine.neonconfiguration files
Usage:
vendor/bin/phpstan analyse bin config public resources src tests --ansi -c vendor/webservco/coding-standards/phpstan/phpstan.neon --level=max
PHPUnit
Composer scripts example:
{
	"scripts": {
		"test" : "XDEBUG_MODE=coverage vendor/bin/phpunit --colors=always --configuration vendor/webservco/coding-standards/phpunit/phpunit-10.xml --display-deprecations --display-errors --display-incomplete --display-notices --display-skipped --display-warnings",
        "test:dox" : "@test --testdox"
	}
}
Usage:
ddev xdebug on clear && ddev exec XDEBUG_MODE=coverage composer test:dox
Psalm
Usage:
vendor/bin/psalm --config=vendor/webservco/coding-standards/psalm/psalm.xml --no-diff