1 | <?php |
||
11 | class SyntaxCheckNodeVisitor extends \Twig_BaseNodeVisitor |
||
12 | { |
||
13 | /** |
||
14 | * @var array |
||
15 | */ |
||
16 | protected $path = []; |
||
17 | |||
18 | /** |
||
19 | * {@inheritdoc} |
||
20 | */ |
||
21 | public function getPriority() |
||
22 | { |
||
23 | return 0; |
||
24 | } |
||
25 | |||
26 | /** |
||
27 | * {@inheritdoc} |
||
28 | * |
||
29 | * @throws \Twig_Error_Syntax |
||
30 | */ |
||
31 | protected function doEnterNode(\Twig_Node $node, \Twig_Environment $env) |
||
32 | { |
||
33 | try { |
||
34 | if ($node instanceof BaseNode) { |
||
35 | $this->checkAllowedParents($node); |
||
36 | } else { |
||
37 | $this->checkAllowedChildren($node); |
||
38 | } |
||
39 | } catch (\Twig_Error_Syntax $e) { |
||
40 | // reset path since throwing an error prevents doLeaveNode to be called |
||
41 | $this->path = []; |
||
42 | throw $e; |
||
43 | } |
||
44 | |||
45 | $this->path[] = $node !== null ? get_class($node) : null; |
||
46 | |||
47 | return $node; |
||
48 | } |
||
49 | |||
50 | /** |
||
51 | * {@inheritdoc} |
||
52 | */ |
||
53 | protected function doLeaveNode(\Twig_Node $node, \ Twig_Environment $env) |
||
59 | |||
60 | /** |
||
61 | * @param \Twig_Node $node |
||
62 | * |
||
63 | * @throws \Twig_Error_Syntax |
||
64 | */ |
||
65 | private function checkAllowedChildren(\Twig_Node $node) |
||
98 | |||
99 | /** |
||
100 | * @param BaseNode $node |
||
101 | * |
||
102 | * @throws \Twig_Error_Syntax |
||
103 | */ |
||
104 | private function checkAllowedParents(BaseNode $node) |
||
130 | } |
||
131 |