rector/rules/Php71/IsArrayAndDualCheckToAble.php
Tomas Votruba a9ba01293d Updated Rector to commit 96fce06e55bc33f941041735100418fd53fe09e2
96fce06e55 [Php73] Add Method Call support on on IsCountableRector (#2762)
2022-08-13 18:43:10 +00:00

73 lines
2.5 KiB
PHP

<?php
declare (strict_types=1);
namespace Rector\Php71;
use PhpParser\Node\Arg;
use PhpParser\Node\Expr;
use PhpParser\Node\Expr\BinaryOp\BooleanOr;
use PhpParser\Node\Expr\FuncCall;
use PhpParser\Node\Expr\Instanceof_;
use PhpParser\Node\Name;
use Rector\Core\NodeManipulator\BinaryOpManipulator;
use Rector\Core\PhpParser\Comparing\NodeComparator;
use Rector\NodeNameResolver\NodeNameResolver;
use Rector\Php71\ValueObject\TwoNodeMatch;
final class IsArrayAndDualCheckToAble
{
/**
* @readonly
* @var \Rector\Core\NodeManipulator\BinaryOpManipulator
*/
private $binaryOpManipulator;
/**
* @readonly
* @var \Rector\NodeNameResolver\NodeNameResolver
*/
private $nodeNameResolver;
/**
* @readonly
* @var \Rector\Core\PhpParser\Comparing\NodeComparator
*/
private $nodeComparator;
public function __construct(BinaryOpManipulator $binaryOpManipulator, NodeNameResolver $nodeNameResolver, NodeComparator $nodeComparator)
{
$this->binaryOpManipulator = $binaryOpManipulator;
$this->nodeNameResolver = $nodeNameResolver;
$this->nodeComparator = $nodeComparator;
}
public function processBooleanOr(BooleanOr $booleanOr, string $type, string $newMethodName) : ?FuncCall
{
$twoNodeMatch = $this->binaryOpManipulator->matchFirstAndSecondConditionNode($booleanOr, Instanceof_::class, FuncCall::class);
if (!$twoNodeMatch instanceof TwoNodeMatch) {
return null;
}
/** @var Instanceof_ $instanceofExpr */
$instanceofExpr = $twoNodeMatch->getFirstExpr();
/** @var FuncCall $funcCallExpr */
$funcCallExpr = $twoNodeMatch->getSecondExpr();
$instanceOfClass = $instanceofExpr->class;
if ($instanceOfClass instanceof Expr) {
return null;
}
if ((string) $instanceOfClass !== $type) {
return null;
}
if (!$this->nodeNameResolver->isName($funcCallExpr, 'is_array')) {
return null;
}
if (!isset($funcCallExpr->args[0])) {
return null;
}
if (!$funcCallExpr->args[0] instanceof Arg) {
return null;
}
$firstExprNode = $funcCallExpr->args[0]->value;
if (!$this->nodeComparator->areNodesEqual($instanceofExpr->expr, $firstExprNode)) {
return null;
}
// both use same Expr
return new FuncCall(new Name($newMethodName), [new Arg($firstExprNode)]);
}
}