szepeviktor / phpstan-wordpress
WordPress extensions for PHPStan
Fund package maintenance!
szepeviktor
Installs: 3 638 040
Dependents: 594
Suggesters: 20
Security: 0
Stars: 277
Watchers: 12
Forks: 27
Open Issues: 12
Type:phpstan-extension
Requires
- php: ^7.4 || ^8.0
- php-stubs/wordpress-stubs: ^6.6.2
- phpstan/phpstan: ^2.0
Requires (Dev)
- composer/composer: ^2.1.14
- dealerdirect/phpcodesniffer-composer-installer: ^1.0
- php-parallel-lint/php-parallel-lint: ^1.1
- phpstan/phpstan-strict-rules: ^2.0
- phpunit/phpunit: ^9.0
- szepeviktor/phpcs-psr-12-neutron-hybrid-ruleset: ^1.0
- wp-coding-standards/wpcs: 3.1.0 as 2.3.0
Suggests
- swissspidy/phpstan-no-private: Detect usage of internal core functions, classes and methods
- dev-master
- 2.x-dev
- v2.0.1
- v2.0.0
- v2.0.0-rc.3
- v2.0.0-rc.2
- v2.0.0-rc.1
- v1.3.5
- v1.3.4
- v1.3.3
- v1.3.2
- v1.3.1
- v1.3.0
- v1.2.0
- v1.1.7
- v1.1.6
- v1.1.5
- v1.1.4
- v1.1.3
- v1.1.2
- v1.1.1
- v1.1.0
- v1.0.5
- v1.0.4
- v1.0.3
- v1.0.2
- v1.0.1
- v1.0.0
- v0.7.7
- v0.7.6
- v0.7.5
- v0.7.4
- v0.7.3
- v0.7.2
- v0.7.1
- v0.7.0
- v0.6.6
- v0.6.5
- v0.6.4
- v0.6.3
- v0.6.2
- v0.6.1
- v0.6.0
- v0.5.0
- v0.4.0
- v0.3.0
- 0.2.1
- 0.2.0
- 0.1.3
- 0.1.2
- 0.1.1
- 0.1.0
This package is auto-updated.
Last update: 2025-01-17 02:33:33 UTC
README
Important
Hello everyone! This is Viktor who runs this PHPStan extension. I am planning to stop contributing to the WordPress ecosystem because it is extremely difficult and no one asks me to join his team as I am a thinker, a devops person, a tool maker (not a builder).
Please support my work to avoid abandoning this package.
Thank you!
WordPress Extensions for PHPStan
Static analysis for the WordPress ecosystem.
Features
- Enables PHPStan to analyze WordPress plugins and themes.
- Loads the
php-stubs/wordpress-stubs
package. - Provides dynamic return type extensions for functions that are not covered in
php-stubs/wordpress-stubs
- Defines some WordPress core constants.
- Validates optional docblocks before
apply_filters()
anddo_action()
calls, treating the type of the first@param
as definitive.
Requirements
- PHPStan 2.0 or higher
- PHP 7.4 or higher (tested up to PHP 8.3)
Installation
To use this extension, require it in Composer:
composer require --dev szepeviktor/phpstan-wordpress
If you also install phpstan/extension-installer then you're all set!
Manual Installation
If you don't want to use phpstan/extension-installer
, include extension.neon
in your project's PHPStan config:
includes: - vendor/szepeviktor/phpstan-wordpress/extension.neon
Configuration
No additional setup is needed. 😃 Just configure PHPStan - for example - as shown below:
parameters: level: 5 paths: - plugin.php - inc/
For more details, visit the PHPStan Config Reference.
💡 Use the Composer autoloader or a custom autoloader!
Usage
Run the analysis with:
vendor/bin/phpstan analyze
then fix an error and GOTO 10
!
You find further information in the examples
directory,
e.g. examples/phpstan.neon.dist
Usage in WooCommerce Webshops
Refer to WooCommerce Stubs for specific guidance.
Usage of an apply_filters()
Docblock
The WordPress ecosystem often uses PHPDoc docblocks in a non-standard way to
document parameters passed to apply_filters()
.
Here’s an example:
/** * Filters the page title when creating an HTML drop-down list of pages. * * @param string $title Page title. * @param WP_Post $page Page data object. */ $title = apply_filters( 'list_pages', $title, $page );
This extension reads these docblocks and instructs PHPStan to treat the filter’s
return type as certain, based on the first @param
tag. In this example,
PHPStan interprets $title
as string
.
For best results, ensure the first @param
tag in these docblocks is accurate.
Make Your Code Testable
- Write clean OOP code: 1 class per file, and no additional code outside
class Name { ... }
. - Use consistent class naming (WPCS or PSR-4) and store classes in a dedicated
inc/
directory. - Add precise PHPDoc blocks to classes, properties, methods, functions, and
apply_filters()
calls. - Choose your main plugin file parts.
- Avoid using core constants, use core functions.
- Avoid bad PHP practices, such as:
- functions:
eval
,extract
,compact
,list
- type juggling:
$a = '15'; if ($a) ...
- functions:
- If you need robust code try avoiding all kinds of type juggling (e.g.
if
needs a boolean), see Variable handling functions - Avoid enabling
exit_error
inWP_CLI::launch
orWP_CLI::runcommand
for improved testability.
Dirty Corner (FAQ)
WordPress uses conditional function and class definition to allow overrides.
Use sed
command to exclude function stubs when they are previously defined.
sed -i -e 's#function is_gd_image#function __is_gd_image#' vendor/php-stubs/wordpress-stubs/wordpress-stubs.php