1
0
mirror of https://github.com/danog/PHP-Parser.git synced 2024-12-04 10:18:09 +01:00
PHP-Parser/lib/PHPParser/NodeVisitor.php
nikic d53173c2f3 Don't use references in NodeTraverser
Stop using reference magic in the NodeTraverser. Instead use normal return values. Additionally enfore that an array is passed to ->traverse().
2011-09-24 23:39:05 +02:00

58 lines
1.6 KiB
PHP

<?php
interface PHPParser_NodeVisitor
{
/**
* Called once before traversal.
*
* Return value semantics:
* * null: $nodes stays as-is
* * otherwise: $nodes is set to the return value
*
* @param PHPParser_Node[] $nodes Array of nodes
*
* @return null|PHPParser_Node[] Array of nodes
*/
public function beforeTraverse(array $nodes);
/**
* Called when entering a node.
*
* Return value semantics:
* * null: $node stays as-is
* * otherwise: $node is set to the return value
*
* @param PHPParser_Node $node Node
*
* @return null|PHPParser_Node Node
*/
public function enterNode(PHPParser_Node $node);
/**
* Called when leaving a node.
*
* Return value semantics:
* * null: $node stays as-is
* * false: $node is removed from the parent array
* * array: The return value is merged into the parent array (at the position of the $node)
* * otherwise: $node is set to the return value
*
* @param PHPParser_Node $node Node
*
* @return null|PHPParser_Node|false|PHPParser_Node[] Node
*/
public function leaveNode(PHPParser_Node $node);
/**
* Called once after traversal.
*
* Return value semantics:
* * null: $nodes stays as-is
* * otherwise: $nodes is set to the return value
*
* @param PHPParser_Node[] $nodes Array of nodes
*
* @return null|PHPParser_Node[] Array of nodes
*/
public function afterTraverse(array $nodes);
}