-
-
Notifications
You must be signed in to change notification settings - Fork 934
Closed
Description
Bug report
We are bumping into an issue with PHPStan's internal dependency symfony/polyfill-php83 not managing to find the polyfill for str_increment. We are using the latest PHPStan version, combined with PHP 8.1.
It occurs when we do something like:
$str = "";
$str++;
This triggers the bit of code in MutatingScope that calls str_increment.
Here's our version info:
PHP runtime version: 8.1.33
PHP composer.json required version: 8.1-8.5.99
PHP version for analysis: 8.1.8 (from config.php in composer.json)
PHPStan version: 2.1.27
And the stacktrace we got:
Internal error: Class "Symfony\Polyfill\Php83\Php83" not found while analysing file /builds/apps/foo/src/Foo.php
Post the following stack trace to https://github.com/phpstan/phpstan/issues/new?template=Bug_report.yaml:
## phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/vendor/symfony/polyfill-php83/bootstrap.php(33)
#0 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/MutatingScope.php(1296): str_increment()
#1 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/MutatingScope.php(621): PHPStan\Analyser\MutatingScope->resolveType()
#2 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/NodeScopeResolver.php(4233): PHPStan\Analyser\MutatingScope->getType()
#3 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/NodeScopeResolver.php(2877): PHPStan\Analyser\NodeScopeResolver->processAssignVar()
#4 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/NodeScopeResolver.php(829): PHPStan\Analyser\NodeScopeResolver->processExprNode()
#5 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/NodeScopeResolver.php(520): PHPStan\Analyser\NodeScopeResolver->processStmtNode()
#6 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/MutatingScope.php(1128): PHPStan\Analyser\NodeScopeResolver->processStmtNodes()
#7 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/MutatingScope.php(621): PHPStan\Analyser\MutatingScope->resolveType()
#8 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Rules/FunctionCallParametersCheck.php(219): PHPStan\Analyser\MutatingScope->getType()
#9 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Rules/Methods/CallMethodsRule.php(64): PHPStan\Rules\FunctionCallParametersCheck->check()
#10 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Rules/Methods/CallMethodsRule.php(49): PHPStan\Rules\Methods\CallMethodsRule->processSingleMethodCall()
#11 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/FileAnalyser.php(129): PHPStan\Rules\Methods\CallMethodsRule->processNode()
#12 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Node/ClassStatementsGatherer.php(116): PHPStan\Analyser\FileAnalyser->PHPStan\Analyser\{closure}()
#13 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/NodeScopeResolver.php(714): PHPStan\Node\ClassStatementsGatherer->__invoke()
#14 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/NodeScopeResolver.php(818): PHPStan\Analyser\NodeScopeResolver::PHPStan\Analyser\{closure}()
#15 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/NodeScopeResolver.php(3532): PHPStan\Analyser\NodeScopeResolver::PHPStan\Analyser\{closure}()
#16 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/NodeScopeResolver.php(1981): PHPStan\Analyser\NodeScopeResolver->callNodeCallbackWithExpression()
#17 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/NodeScopeResolver.php(829): PHPStan\Analyser\NodeScopeResolver->processExprNode()
#18 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/NodeScopeResolver.php(520): PHPStan\Analyser\NodeScopeResolver->processStmtNode()
#19 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/NodeScopeResolver.php(739): PHPStan\Analyser\NodeScopeResolver->processStmtNodes()
#20 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/NodeScopeResolver.php(520): PHPStan\Analyser\NodeScopeResolver->processStmtNode()
#21 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/NodeScopeResolver.php(897): PHPStan\Analyser\NodeScopeResolver->processStmtNodes()
#22 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/NodeScopeResolver.php(520): PHPStan\Analyser\NodeScopeResolver->processStmtNode()
#23 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/NodeScopeResolver.php(848): PHPStan\Analyser\NodeScopeResolver->processStmtNodes()
#24 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/NodeScopeResolver.php(468): PHPStan\Analyser\NodeScopeResolver->processStmtNode()
#25 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Analyser/FileAnalyser.php(203): PHPStan\Analyser\NodeScopeResolver->processNodes()
#26 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Command/WorkerCommand.php(149): PHPStan\Analyser\FileAnalyser->analyseFile()
#27 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/vendor/evenement/evenement/src/EventEmitterTrait.php(111): PHPStan\Command\WorkerCommand::PHPStan\Command\{closure}()
#28 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/vendor/clue/ndjson-react/src/Decoder.php(117): _PHPStan_33359be5f\Evenement\EventEmitter->emit()
#29 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/vendor/evenement/evenement/src/EventEmitterTrait.php(111): _PHPStan_33359be5f\Clue\React\NDJson\Decoder->handleData()
#30 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/vendor/react/stream/src/Util.php(62): _PHPStan_33359be5f\Evenement\EventEmitter->emit()
#31 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/vendor/evenement/evenement/src/EventEmitterTrait.php(111): _PHPStan_33359be5f\React\Stream\Util::_PHPStan_33359be5f\React\Stream\{closure}()
#32 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/vendor/react/stream/src/DuplexResourceStream.php(168): _PHPStan_33359be5f\Evenement\EventEmitter->emit()
#33 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/vendor/react/event-loop/src/StreamSelectLoop.php(201): _PHPStan_33359be5f\React\Stream\DuplexResourceStream->handleData()
#34 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/vendor/react/event-loop/src/StreamSelectLoop.php(173): _PHPStan_33359be5f\React\EventLoop\StreamSelectLoop->waitForStreamActivity()
#35 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/src/Command/WorkerCommand.php(105): _PHPStan_33359be5f\React\EventLoop\StreamSelectLoop->run()
#36 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/vendor/symfony/console/Command/Command.php(259): PHPStan\Command\WorkerCommand->execute()
#37 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/vendor/symfony/console/Application.php(868): _PHPStan_33359be5f\Symfony\Component\Console\Command\Command->run()
#38 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/vendor/symfony/console/Application.php(261): _PHPStan_33359be5f\Symfony\Component\Console\Application->doRunCommand()
#39 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/vendor/symfony/console/Application.php(157): _PHPStan_33359be5f\Symfony\Component\Console\Application->doRun()
#40 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/bin/phpstan(96): _PHPStan_33359be5f\Symfony\Component\Console\Application->run()
#41 phar:///builds/apps/foo/vendor/phpstan/phpstan/phpstan.phar/bin/phpstan(97): _PHPStan_33359be5f\{closure}()
#42 /builds/apps/foo/vendor/phpstan/phpstan/phpstan(8): require('...')
#43 /builds/apps/foo/vendor/bin/phpstan(119): include('...')
#44 {main}
Code snippet that reproduces the problem
No response
Expected output
No exception.
Did PHPStan help you today? Did it make you happy in any way?
No response
Metadata
Metadata
Assignees
Labels
No labels