php-parser/lib/PhpParser/NodeVisitor.php

73 lines
2.0 KiB
PHP
Raw Permalink Normal View History

2017-08-18 22:57:27 +02:00
<?php declare(strict_types=1);
2011-08-09 09:27:47 +02:00
namespace PhpParser;
interface NodeVisitor
2011-08-09 09:27:47 +02:00
{
/**
* Called once before traversal.
*
* Return value semantics:
* * null: $nodes stays as-is
* * otherwise: $nodes is set to the return value
*
* @param Node[] $nodes Array of nodes
*
* @return null|Node[] Array of nodes
2011-08-09 09:27:47 +02:00
*/
public function beforeTraverse(array $nodes);
2011-08-09 09:27:47 +02:00
/**
* Called when entering a node.
*
* Return value semantics:
2017-01-25 23:28:44 +01:00
* * null
* => $node stays as-is
* * NodeTraverser::DONT_TRAVERSE_CHILDREN
* => Children of $node are not traversed. $node stays as-is
* * NodeTraverser::STOP_TRAVERSAL
* => Traversal is aborted. $node stays as-is
2017-01-25 23:28:44 +01:00
* * otherwise
* => $node is set to the return value
*
* @param Node $node Node
*
* @return null|int|Node Replacement node (or special return value)
2011-08-09 09:27:47 +02:00
*/
public function enterNode(Node $node);
2011-08-09 09:27:47 +02:00
/**
* Called when leaving a node.
*
* Return value semantics:
2017-01-25 23:28:44 +01:00
* * null
* => $node stays as-is
* * NodeTraverser::REMOVE_NODE
* => $node is removed from the parent array
* * NodeTraverser::STOP_TRAVERSAL
* => Traversal is aborted. $node stays as-is
2017-01-25 23:28:44 +01:00
* * array (of Nodes)
* => The return value is merged into the parent array (at the position of the $node)
* * otherwise
* => $node is set to the return value
*
* @param Node $node Node
*
* @return null|int|Node|Node[] Replacement node (or special return value)
2011-08-09 09:27:47 +02:00
*/
public function leaveNode(Node $node);
2011-08-09 09:27:47 +02:00
/**
* Called once after traversal.
*
* Return value semantics:
* * null: $nodes stays as-is
* * otherwise: $nodes is set to the return value
*
* @param Node[] $nodes Array of nodes
*
* @return null|Node[] Array of nodes
2011-08-09 09:27:47 +02:00
*/
public function afterTraverse(array $nodes);
2018-01-10 18:04:06 +01:00
}