fabianblum / phpcs-psr4-sniff
PHP_CodeSniffer sniff that checks class name matches PSR-4 project structure. (PHP 8.3 ready)
Installs: 17 314
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 0
Forks: 16
Type:phpcodesniffer-standard
pkg:composer/fabianblum/phpcs-psr4-sniff
Requires
- php: >=7.1
- ext-json: *
- slevomat/coding-standard: >=4.7 <9.0.0
- squizlabs/php_codesniffer: >=3.3 <4.0.0
This package is auto-updated.
Last update: 2025-10-01 00:09:35 UTC
README
A custom PHP Code Sniffer sniff to help to find classes that is not compliant with PSR-4 Autoloader.
Public fork of abandoned package
This package was originally hosted at https://github.com/suin/phpcs-psr4-sniff, but seems to be abandoned. For ease of migration, the original namespacing has been kept.
To switch to this package, use the commands
composer remove suin/phpcs-psr4-sniff
composer require fabianblum/phpcs-psr4-sniff
Demo
Please visit ./tests/demo, if you would like to try this sniff.
Features
Classes, interfaces and traits
This sniff covers not only classes but also interfaces and traits.
Namespaces and class names
This sniff checks whether both of namespaces and class names match PSR-4 project structure.
Configuration free
As this sniff respects composer.json autoloading configuration, you don't have to declare mapping between namespace prefixes and base directories.
Similar packages
Psr4Fixer of PHP-CS-Fixer
Psr4Fixer checkes if class names should match the file name and fixes the class names if its don't correspond to the file names. It doesn't check the namespaces.
In contrast, this package checks not only class names but also namespaces.
SlevomatCodingStandard.Files.TypeNameMatchesFileName
SlevomatCodingStandard.Files.TypeNameMatchesFileName is a custom PHP Code Sniffer sniff to check whether namespaces and class names follow PSR-0/PSR-4 project structure.
This sniff is similar to suin/phpcs-psr4-sniff, but it needs explicit configuration about the PSR-0/PSR-4 project structure. suin/phpcs-psr4-sniff takes implicit way as it follows the autoloding configuration of Composer.
Installation
composer require --dev suin/phpcs-psr4-sniff
Usage
At first, create a PHPCS ruleset XML (phpcs.xml.dist or phpcs.xml) file in the root of your project.
<?xml version="1.0"?> <ruleset name="My Project"> <!-- Specify directory that composer.json is placed. Usually it would be project root directory. --> <arg name="basepath" value="."/> <!-- Relative path to your ruleset.xml --> <rule ref="vendor/suin/phpcs-psr4-sniff/src/Suin"/> <!-- Optional: If you have to specify composer.json path, please add following section. --> <rule ref="Suin.Classes.PSR4"> <properties> <!-- composerJsonPath must be relative path to "basepath" --> <property name="composerJsonPath" value="sub-dir/composer.json"/> </properties> </rule> </ruleset>
Then run it with the command:
vendor/bin/phpcs src
Changelog
Please see CHANGELOG for more details.
Contributing
Send issue or pull-request to main repository.
