automattic / jetpack-codesniffer
Jetpack Coding Standards. Based on the WordPress Coding Standards, with some additions.
Installs: 48 135
Dependents: 1
Suggesters: 0
Security: 0
Stars: 1
Watchers: 3
Forks: 1
Type:phpcodesniffer-standard
Requires
- php: >=7.4
- automattic/vipwpcs: ^3.0
- dealerdirect/phpcodesniffer-composer-installer: ^1.0
- mediawiki/mediawiki-codesniffer: ^43.0
- phpcompatibility/phpcompatibility-wp: ^2.1
- sirbrillig/phpcs-variable-analysis: ^2.10
- wp-coding-standards/wpcs: ^3.0
Requires (Dev)
- automattic/jetpack-changelogger: ^4.2.6
- yoast/phpunit-polyfills: ^1.1.1
- dev-trunk / 5.0.x-dev
- v4.0.0
- v3.0.0
- v2.8.0
- v2.7.0
- v2.6.1
- v2.6.0
- v2.5.0
- v2.4.0
- v2.3.0
- v2.2.1
- v2.2.0
- v2.1.1
- v2.1.0
- v2.0.0
- v1.1.0
- v1.0.0
- dev-fix/slack-workflow-branch-detection
- dev-fix/release-branch-typo
- dev-update/generate-branch-plugin
- dev-release-v2.2.0
- dev-release-v2.1.1
- dev-feature/reorg
- dev-release-v2.1.0
- dev-release-v2.0.0
- dev-release-v1.1.0
- dev-release-v1.0.0
This package is auto-updated.
Last update: 2024-11-05 22:04:57 UTC
README
This is a package implementing phpcs sniffs for the Jetpack Coding Standard.
This standard is generally that of WordPress, with a few additions.
Usage
In your project's composer.json
, add the following lines:
{ "require-dev": { "dealerdirect/phpcodesniffer-composer-installer": "*", "automattic/jetpack-codesniffer": "^1" } }
Your project must use the default composer vendor directory, vendor
.
You should then include the Jetpack rules in your .phpcs.xml.dist
, like
<rule ref="Jetpack" />
You will also likely want to set some configuration for other included rulesets:
<config name="minimum_supported_wp_version" value="6.3" /> <config name="testVersion" value="7.0-"/>
Included Standards
The Jetpack standard includes the following other standards:
- PHPCompatibilityWP
- WordPress-Core, WordPress-Docs, and WordPress-Extra
- VariableAnalysis
- Selected sniffs from MediaWiki
Per-dir Compatibility
This ruleset is intended to be used with PHPCompatibiity's testVersion
set to 7.0-
.
If used with automattic/jetpack-phpcs-filter's per-directory configuration,
you may run into a situation where a subdir wants to be compatible down to a later version, but as PHPCompatibiity uses <config>
for testVersion
the setting cannot be directly altered per directory.
To assist with this case, we provide additional rulesets that disable PHPCompatibility rules detecting issues that only apply to older versions:
<rule ref="Jetpack-Compat-71" />
will disable rules detecting issues that only apply to PHP < 7.1.<rule ref="Jetpack-Compat-72" />
will disable rules detecting issues that only apply to PHP < 7.2.<rule ref="Jetpack-Compat-73" />
will disable rules detecting issues that only apply to PHP < 7.3.<rule ref="Jetpack-Compat-74" />
will disable rules detecting issues that only apply to PHP < 7.4.<rule ref="Jetpack-Compat-80" />
will disable rules detecting issues that only apply to PHP < 8.0.<rule ref="Jetpack-Compat-81" />
will disable rules detecting issues that only apply to PHP < 8.1.<rule ref="Jetpack-Compat-82" />
will disable rules detecting issues that only apply to PHP < 8.2.<rule ref="Jetpack-Compat-83" />
will disable rules detecting issues that only apply to PHP < 8.3.
Note this isn't a perfect replacement for raising testVersion
, as it cannot add PHPCompatibility rules that do not trigger when testVersion
indicates support for PHP 7.0.
For example, Jetpack-Compat-74
disables the PHPCompatibility.Classes.NewTypedProperties.Found
rule ("Typed properties are not supported in PHP 7.3 or earlier") but cannot enable more specific rules like PHPCompatibility.Classes.NewTypedProperties.UnionTypeFound
("Union types are not present in PHP version 7.4 or earlier") that would be triggered if testVersion
were set to 7.4-
.
You may also run into cases where certain subdirectories contain code that is not intended to run under WordPress. We provide additional rulesets to help with this situation as well:
<rule ref="Jetpack-Compat-NoWP" />
will re-enable rules that PHPCompatibilityWP disables because WordPress provides polyfills for various functions.<rule ref="Jetpack-NoWP" />
includes Jetpack-Compat-NoWP and disables additional rules checking for use of WordPress-provided functions over PHP-native ones.<rule ref="Jetpack-Tests" />
will disable certain rules that do not make much sense in PHPUnit tests.