-
Notifications
You must be signed in to change notification settings - Fork 64
/
Copy pathNodeVisitorForTesting.php
78 lines (64 loc) · 1.59 KB
/
NodeVisitorForTesting.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
<?php declare(strict_types = 1);
namespace PHPStan\PhpDocParser\Ast;
use Exception;
use function count;
/**
* Inspired by https://github.com/nikic/PHP-Parser/tree/36a6dcd04e7b0285e8f0868f44bd4927802f7df1
*
* Copyright (c) 2011, Nikita Popov
* All rights reserved.
*/
class NodeVisitorForTesting implements NodeVisitor
{
/** @var list<array{string, Node|Node[]}> */
public array $trace = [];
/** @var list<list<mixed>> */
private array $returns;
private int $returnsPos;
/**
* @param list<list<mixed>> $returns
*/
public function __construct(array $returns = [])
{
$this->returns = $returns;
$this->returnsPos = 0;
}
public function beforeTraverse(array $nodes): ?array
{
return $this->traceEvent('beforeTraverse', $nodes);
}
public function enterNode(Node $node)
{
return $this->traceEvent('enterNode', $node);
}
public function leaveNode(Node $node)
{
return $this->traceEvent('leaveNode', $node);
}
public function afterTraverse(array $nodes): ?array
{
return $this->traceEvent('afterTraverse', $nodes);
}
/**
* @param Node|Node[] $param
* @return mixed
*/
private function traceEvent(string $method, $param)
{
$this->trace[] = [$method, $param];
if ($this->returnsPos < count($this->returns)) {
$currentReturn = $this->returns[$this->returnsPos];
if ($currentReturn[0] === $method && $currentReturn[1] === $param) {
$this->returnsPos++;
return $currentReturn[2];
}
}
return null;
}
public function __destruct()
{
if ($this->returnsPos !== count($this->returns)) {
throw new Exception('Expected event did not occur');
}
}
}