Download the PHP package szepeviktor/phpstan-wordpress without Composer
On this page you can find all versions of the php package szepeviktor/phpstan-wordpress. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download szepeviktor/phpstan-wordpress
More information about szepeviktor/phpstan-wordpress
Files in szepeviktor/phpstan-wordpress
Package phpstan-wordpress
Short Description WordPress extensions for PHPStan
License MIT
Informations about the package phpstan-wordpress
[!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:
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:
Configuration
No additional setup is needed. :smiley: Just configure PHPStan - for example - as shown below:
For more details, visit the PHPStan Config Reference.
:bulb: Use the Composer autoloader or a custom autoloader!
Usage
Run the analysis with:
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:
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.
All versions of phpstan-wordpress with dependencies
php-stubs/wordpress-stubs Version ^6.6.2
phpstan/phpstan Version ^2.0