mirror of
https://github.com/rectorphp/rector.git
synced 2025-01-17 13:28:18 +01:00
9a4a5b2bc5
eb5df4dde7
Use vendor-patches main branch (#6453)
71 lines
2.4 KiB
PHP
71 lines
2.4 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\NodeManipulator\BinaryOpManipulator;
|
|
use Rector\NodeNameResolver\NodeNameResolver;
|
|
use Rector\Php71\ValueObject\TwoNodeMatch;
|
|
use Rector\PhpParser\Comparing\NodeComparator;
|
|
final class IsArrayAndDualCheckToAble
|
|
{
|
|
/**
|
|
* @readonly
|
|
*/
|
|
private BinaryOpManipulator $binaryOpManipulator;
|
|
/**
|
|
* @readonly
|
|
*/
|
|
private NodeNameResolver $nodeNameResolver;
|
|
/**
|
|
* @readonly
|
|
*/
|
|
private NodeComparator $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 ($funcCallExpr->isFirstClassCallable()) {
|
|
return null;
|
|
}
|
|
if (!isset($funcCallExpr->getArgs()[0])) {
|
|
return null;
|
|
}
|
|
$firstArg = $funcCallExpr->getArgs()[0];
|
|
$firstExprNode = $firstArg->value;
|
|
if (!$this->nodeComparator->areNodesEqual($instanceofExpr->expr, $firstExprNode)) {
|
|
return null;
|
|
}
|
|
// both use same Expr
|
|
return new FuncCall(new Name($newMethodName), [new Arg($firstExprNode)]);
|
|
}
|
|
}
|