nette / phpstan-rules
🐘 PHPStan rules and type extensions for Nette libraries
Requires
- php: 8.1 - 8.5
- phpstan/phpstan: ^2.1.40
Requires (Dev)
- nette/component-model: ^3.1
- nette/forms: ^3.2
- nette/schema: ^1.3
- nette/tester: ^2.6
This package is auto-updated.
Last update: 2026-03-04 09:04:25 UTC
README
Makes PHPStan smarter about Nette code. Install, and it just works — more precise types, fewer false positives.
Installation
Install via Composer:
composer require --dev nette/phpstan-rules
Requirements: PHP 8.1 or higher and PHPStan 2.1+.
If you use phpstan/extension-installer, the extension is registered automatically. Otherwise add to your phpstan.neon:
includes: - vendor/nette/phpstan-rules/extension.neon
What's Included
Precise return types — narrows return types of Strings::match(), matchAll(), split(), Helpers::falseToNull(), Expect::array(), Arrays::invoke(), and Arrays::invokeMethod() based on the arguments you pass. Also narrows Container::getComponent() and $container['...'] to match the corresponding createComponent*() factory return type. For forms, $form['name'] returns the specific control type (e.g. TextInput, SelectBox) based on the addText(), addSelect(), etc. call in the same function.
Removes |false and |null from PHP functions — many native functions like getcwd, json_encode, preg_split, preg_replace, and many more include false or null in their return type even though these error values are unrealistic on modern systems.
Assert type narrowing — PHPStan understands type guarantees after Tester\Assert calls like notNull(), type(), true(), etc.
False positive suppression — silences known PHPStan false positives in Nette patterns (arrow functions passed as void callbacks, runtime type validation closures).
Type Assertion Testing Helper
For Nette package developers: TypeAssert lets you verify type inference in tests using Nette Tester:
use Nette\PHPStan\Tester\TypeAssert; TypeAssert::assertTypes(__DIR__ . '/data/types.php'); TypeAssert::assertNoErrors(__DIR__ . '/data/clean.php');
The data file uses assertType() from PHPStan:
use function PHPStan\Testing\assertType; assertType('non-empty-string', getcwd()); assertType('string', Normalizer::normalize('foo'));
Support Me
Do you like Nette? Are you looking forward to the new features?
Thank you!