From 992d1efc7596864c960b3a9837ebf8ee04eb159d Mon Sep 17 00:00:00 2001 From: Abdul Malik Ikhsan Date: Mon, 2 May 2022 16:37:50 +0700 Subject: [PATCH] [CodeQuality] Skip CallableThisArrayToAnonymousFunctionRector when inside of Attribute (#2212) * [CodeQuality] Skip CallableThisArrayToAnonymousFunctionRector when inside of Attribute * Fixed :tada: --- .../ArrayCallableMethodMatcher.php | 6 +++++ .../Fixture/skip_in_attribute.php.inc | 22 +++++++++++++++++++ .../Source/LocaleUtils.php | 13 +++++++++++ 3 files changed, 41 insertions(+) create mode 100644 rules-tests/CodeQuality/Rector/Array_/CallableThisArrayToAnonymousFunctionRector/Fixture/skip_in_attribute.php.inc create mode 100644 rules-tests/CodeQuality/Rector/Array_/CallableThisArrayToAnonymousFunctionRector/Source/LocaleUtils.php diff --git a/packages/NodeCollector/NodeAnalyzer/ArrayCallableMethodMatcher.php b/packages/NodeCollector/NodeAnalyzer/ArrayCallableMethodMatcher.php index 8925c513f7f..f7cc845669b 100644 --- a/packages/NodeCollector/NodeAnalyzer/ArrayCallableMethodMatcher.php +++ b/packages/NodeCollector/NodeAnalyzer/ArrayCallableMethodMatcher.php @@ -5,6 +5,7 @@ namespace Rector\NodeCollector\NodeAnalyzer; use PhpParser\Node\Arg; +use PhpParser\Node\Attribute; use PhpParser\Node\Expr\Array_; use PhpParser\Node\Expr\ArrayItem; use PhpParser\Node\Expr\ClassConstFetch; @@ -71,6 +72,11 @@ public function match(Array_ $array): null | ArrayCallableDynamicMethod | ArrayC return null; } + $isInAttribute = (bool) $this->betterNodeFinder->findParentType($array, Attribute::class); + if ($isInAttribute) { + return null; + } + $values = $this->valueResolver->getValue($array); $className = $calleeType->getClassName(); $secondItemValue = $items[1]->value; diff --git a/rules-tests/CodeQuality/Rector/Array_/CallableThisArrayToAnonymousFunctionRector/Fixture/skip_in_attribute.php.inc b/rules-tests/CodeQuality/Rector/Array_/CallableThisArrayToAnonymousFunctionRector/Fixture/skip_in_attribute.php.inc new file mode 100644 index 00000000000..371874dbccb --- /dev/null +++ b/rules-tests/CodeQuality/Rector/Array_/CallableThisArrayToAnonymousFunctionRector/Fixture/skip_in_attribute.php.inc @@ -0,0 +1,22 @@ +locale; + } + + public function setLocale(?string $locale): Account + { + $this->locale = $locale; + return $this; + } +} diff --git a/rules-tests/CodeQuality/Rector/Array_/CallableThisArrayToAnonymousFunctionRector/Source/LocaleUtils.php b/rules-tests/CodeQuality/Rector/Array_/CallableThisArrayToAnonymousFunctionRector/Source/LocaleUtils.php new file mode 100644 index 00000000000..311405b3db3 --- /dev/null +++ b/rules-tests/CodeQuality/Rector/Array_/CallableThisArrayToAnonymousFunctionRector/Source/LocaleUtils.php @@ -0,0 +1,13 @@ +