1 | <?php |
||
14 | trait ResolveExpressionTrait |
||
15 | { |
||
16 | /** |
||
17 | * @param FuncCall $funcCall |
||
18 | * @param Context $context |
||
19 | * @return string|bool |
||
20 | */ |
||
21 | 15 | public function resolveFunctionName(FuncCall $funcCall, Context $context) |
|
36 | |||
37 | /** |
||
38 | * @param array $nodes |
||
39 | * @param string $nodeName Class name of Node(s) what We should return |
||
40 | * @return \Generator |
||
41 | */ |
||
42 | 12 | protected function findNode(array $nodes, $nodeName) |
|
50 | |||
51 | /** |
||
52 | * For the code above |
||
53 | * Я атеист, но когда я начинал это писать, только Бог и я понимали, что я делаю |
||
54 | * Сейчас остался только Бог |
||
55 | * |
||
56 | * @param Node $node |
||
57 | * @return \Generator |
||
58 | * |
||
59 | * @todo After move to PHP 7.0+ use yield from |
||
60 | */ |
||
61 | 12 | protected function traverseNode(Node $node) |
|
62 | { |
||
63 | // Skip inherits nodes |
||
64 | 12 | if ($node instanceof Node\FunctionLike || $node instanceof Node\Stmt\ClassLike) { |
|
65 | 1 | return; |
|
66 | } |
||
67 | |||
68 | 12 | foreach ($node->getSubNodeNames() as $name) { |
|
69 | 12 | $subNode = &$node->$name; |
|
70 | |||
71 | 12 | if (is_array($subNode)) { |
|
72 | 8 | foreach ($this->traverseArray($subNode) as $rNode) { |
|
73 | 7 | yield $rNode; |
|
74 | 8 | } |
|
75 | 12 | } elseif ($subNode instanceof Node) { |
|
76 | 10 | yield $subNode; |
|
77 | |||
78 | 10 | foreach ($this->traverseNode($subNode) as $rNode) { |
|
79 | 7 | yield $rNode; |
|
80 | 10 | } |
|
81 | 10 | } |
|
82 | 12 | } |
|
83 | 12 | } |
|
84 | |||
85 | /** |
||
86 | * @param array $nodes |
||
87 | * @return \Generator |
||
88 | */ |
||
89 | 12 | protected function traverseArray(array $nodes) |
|
105 | } |
||
106 |
Very long variable names usually make code harder to read. It is therefore recommended not to make variable names too verbose.