rector/rules/Php71/IsArrayAndDualCheckToAble.php

90 lines
2.3 KiB
PHP
Raw Normal View History

2019-10-13 07:59:52 +02:00
<?php
declare(strict_types=1);
2018-10-03 22:11:30 +08:00
2019-09-23 18:05:19 +02:00
namespace Rector\Php71;
2018-10-03 22:11:30 +08:00
2018-11-07 21:53:19 +01:00
use PhpParser\Node\Arg;
use PhpParser\Node\Expr;
2018-10-03 22:11:30 +08:00
use PhpParser\Node\Expr\BinaryOp\BooleanOr;
use PhpParser\Node\Expr\FuncCall;
use PhpParser\Node\Expr\Instanceof_;
use PhpParser\Node\Expr\Variable;
use PhpParser\Node\Name;
use Rector\Core\NodeManipulator\BinaryOpManipulator;
use Rector\NodeNameResolver\NodeNameResolver;
use Rector\Php71\ValueObject\TwoNodeMatch;
2018-10-03 22:11:30 +08:00
final class IsArrayAndDualCheckToAble
2018-10-03 22:11:30 +08:00
{
/**
* @var NodeNameResolver
*/
private $nodeNameResolver;
2018-11-07 18:04:38 +01:00
/**
* @var BinaryOpManipulator
2018-11-07 18:04:38 +01:00
*/
private $binaryOpManipulator;
2018-11-07 18:04:38 +01:00
2020-07-26 09:49:22 +02:00
public function __construct(BinaryOpManipulator $binaryOpManipulator, NodeNameResolver $nodeNameResolver)
{
$this->nodeNameResolver = $nodeNameResolver;
$this->binaryOpManipulator = $binaryOpManipulator;
}
2019-02-22 18:25:31 +01:00
public function processBooleanOr(BooleanOr $booleanOr, string $type, string $newMethodName): ?FuncCall
2018-10-03 22:11:30 +08:00
{
$twoNodeMatch = $this->binaryOpManipulator->matchFirstAndSecondConditionNode(
2019-02-22 18:25:31 +01:00
$booleanOr,
Instanceof_::class,
FuncCall::class
2018-11-07 18:04:38 +01:00
);
if (! $twoNodeMatch instanceof TwoNodeMatch) {
2018-10-03 22:11:30 +08:00
return null;
}
/** @var Instanceof_ $instanceOf */
$instanceOf = $twoNodeMatch->getFirstExpr();
/** @var FuncCall $funcCall */
$funcCall = $twoNodeMatch->getSecondExpr();
2018-10-03 22:11:30 +08:00
$instanceOfClass = $instanceOf->class;
if ($instanceOfClass instanceof Expr) {
2020-06-21 16:51:14 +02:00
return null;
}
if ((string) $instanceOfClass !== $type) {
2018-10-03 22:11:30 +08:00
return null;
}
if (! $this->nodeNameResolver->isName($funcCall, 'is_array')) {
2018-10-03 22:11:30 +08:00
return null;
}
// both use same var
if (! $funcCall->args[0]->value instanceof Variable) {
2018-10-03 22:11:30 +08:00
return null;
}
/** @var Variable $firstVarNode */
$firstVarNode = $funcCall->args[0]->value;
2018-10-03 22:11:30 +08:00
if (! $instanceOf->expr instanceof Variable) {
2018-10-03 22:11:30 +08:00
return null;
}
/** @var Variable $secondVarNode */
$secondVarNode = $instanceOf->expr;
2018-10-03 22:11:30 +08:00
// are they same variables
if ($firstVarNode->name !== $secondVarNode->name) {
return null;
}
2018-11-07 21:53:19 +01:00
return new FuncCall(new Name($newMethodName), [new Arg($firstVarNode)]);
2018-10-03 22:11:30 +08:00
}
}