vishwac09 / extended-php-guidelines
Provides set of additional coding/style guidelines to sniff PHP code.
Installs: 2
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:phpcodesniffer-standard
pkg:composer/vishwac09/extended-php-guidelines
Requires
- php: >=7.1
- ext-mbstring: *
- dealerdirect/phpcodesniffer-composer-installer: ^0.7.1
- squizlabs/php_codesniffer: ^3.6.0
Requires (Dev)
- phpunit/phpunit: >=3.7 <6
This package is auto-updated.
Last update: 2023-11-12 15:46:06 UTC
README
Apart from the PSR-1, PSR-2, PSR-12 and the Drupal standard's, we follow few more to achieve consistency of code project wide.
I work mostly on Drupal projects, so normally use the Drupal Coding standard to sniff the custom code for any violations. This PHP library is a type of PHP-CodeSniffer standard which checks PHP code against the below list.
List
- Order of imports - Group Drupal/Symfony imports and third party libraries added via composer separately.
- Avoid Switch case - PHP >= 8.0 provides match() {} expression, can be replaced in place of switch() case:.
- Avoid Static Class references - Cannot be injected.
- Order of member functions - Order member function in ascending order, improves readability.
Usage
Create a project, and add this packages as DEV dependancy.
Installation
Add via composer as local dependencies
composer require --dev dealerdirect/phpcodesniffer-composer-installer
composer require --dev vishwac09/extended-php-guidelines
OR
Add via composer as global dependencies
composer require global --dev dealerdirect/phpcodesniffer-composer-installer
composer require global --dev vishwac09/extended-php-guidelines
Add via GIT
git clone git@github.com:vishwac09/extended-php-guidelines.git
add the standard to phpcs
phpcs --config-set installed_paths /path/to/extended-php-guidelines/EPG
Run
Check if the new stanadard is configures with phpcs.
phpcs -i
Sniff code for the above violation.
phpcs --standard=EPG --colors file1.php, file2.inc
Example
FILE: /Users/hp/Documents/temp.php
------------------------------------------------------------------------------------------------------
FOUND 0 ERRORS AND 5 WARNINGS AFFECTING 5 LINES
------------------------------------------------------------------------------------------------------
  1 | WARNING | Group Drupal/Symfony imports and third party libraries added via composer separately.
 26 | WARNING | Member functions of class must be defined in ascending order
 28 | WARNING | Do not use static class references.
 40 | WARNING | Member functions of interface must be defined in ascending order
 50 | WARNING | Do not use switch expression. With PHP >= 8.0 use the new match expression
    |         | (https://www.php.net/manual/en/control-structures.match.php).
------------------------------------------------------------------------------------------------------