mirror of
https://github.com/zoe-may/TDoG-Skin.git
synced 2025-01-19 16:07:24 +08:00
348 lines
7.3 KiB
PHP
Executable File
348 lines
7.3 KiB
PHP
Executable File
<?php
|
|
|
|
/**
|
|
* Hoa
|
|
*
|
|
*
|
|
* @license
|
|
*
|
|
* New BSD License
|
|
*
|
|
* Copyright © 2007-2017, Hoa community. All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions are met:
|
|
* * Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* * Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
* * Neither the name of the Hoa nor the names of its contributors may be
|
|
* used to endorse or promote products derived from this software without
|
|
* specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS AND CONTRIBUTORS BE
|
|
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
*/
|
|
|
|
namespace Hoa\Compiler\Llk;
|
|
|
|
use Hoa\Visitor;
|
|
|
|
/**
|
|
* Class \Hoa\Compiler\Llk\TreeNode.
|
|
*
|
|
* Provide a generic node for the AST produced by LL(k) parser.
|
|
*
|
|
* @copyright Copyright © 2007-2017 Hoa community
|
|
* @license New BSD License
|
|
*/
|
|
class TreeNode implements Visitor\Element
|
|
{
|
|
/**
|
|
* ID (should be something like #ruleName or token).
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $_id = null;
|
|
|
|
/**
|
|
* Value of the node (non-null for token nodes).
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $_value = null;
|
|
|
|
/**
|
|
* Children.
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $_children = null;
|
|
|
|
/**
|
|
* Parent.
|
|
*
|
|
* @var \Hoa\Compiler\Llk\TreeNode
|
|
*/
|
|
protected $_parent = null;
|
|
|
|
/**
|
|
* Attached data.
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $_data = [];
|
|
|
|
|
|
|
|
/**
|
|
* Constructor.
|
|
*
|
|
* @param string $id ID.
|
|
* @param array $value Value.
|
|
* @param array $children Children.
|
|
* @param \Hoa\Compiler\Llk\TreeNode $parent Parent.
|
|
*/
|
|
public function __construct(
|
|
$id,
|
|
array $value = null,
|
|
array $children = [],
|
|
self $parent = null
|
|
) {
|
|
$this->setId($id);
|
|
|
|
if (!empty($value)) {
|
|
$this->setValue($value);
|
|
}
|
|
|
|
$this->setChildren($children);
|
|
|
|
if (null !== $parent) {
|
|
$this->setParent($parent);
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* Set ID.
|
|
*
|
|
* @param string $id ID.
|
|
* @return string
|
|
*/
|
|
public function setId($id)
|
|
{
|
|
$old = $this->_id;
|
|
$this->_id = $id;
|
|
|
|
return $old;
|
|
}
|
|
|
|
/**
|
|
* Get ID.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getId()
|
|
{
|
|
return $this->_id;
|
|
}
|
|
|
|
/**
|
|
* Set value.
|
|
*
|
|
* @param array $value Value (token & value).
|
|
* @return array
|
|
*/
|
|
public function setValue(array $value)
|
|
{
|
|
$old = $this->_value;
|
|
$this->_value = $value;
|
|
|
|
return $old;
|
|
}
|
|
|
|
/**
|
|
* Get value.
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getValue()
|
|
{
|
|
return $this->_value;
|
|
}
|
|
|
|
/**
|
|
* Get value token.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getValueToken()
|
|
{
|
|
return
|
|
isset($this->_value['token'])
|
|
? $this->_value['token']
|
|
: null;
|
|
}
|
|
|
|
/**
|
|
* Get value value.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getValueValue()
|
|
{
|
|
return
|
|
isset($this->_value['value'])
|
|
? $this->_value['value']
|
|
: null;
|
|
}
|
|
|
|
/**
|
|
* Check if the node represents a token or not.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isToken()
|
|
{
|
|
return !empty($this->_value);
|
|
}
|
|
|
|
/**
|
|
* Prepend a child.
|
|
*
|
|
* @param \Hoa\Compiler\Llk\TreeNode $child Child.
|
|
* @return \Hoa\Compiler\Llk\TreeNode
|
|
*/
|
|
public function prependChild(TreeNode $child)
|
|
{
|
|
array_unshift($this->_children, $child);
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Append a child.
|
|
*
|
|
* @param \Hoa\Compiler\Llk\TreeNode $child Child.
|
|
* @return \Hoa\Compiler\Llk\TreeNode
|
|
*/
|
|
public function appendChild(TreeNode $child)
|
|
{
|
|
$this->_children[] = $child;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Set children.
|
|
*
|
|
* @param array $children Children.
|
|
* @return array
|
|
*/
|
|
public function setChildren(array $children)
|
|
{
|
|
$old = $this->_children;
|
|
$this->_children = $children;
|
|
|
|
return $old;
|
|
}
|
|
|
|
/**
|
|
* Get child.
|
|
*
|
|
* @param int $i Index.
|
|
* @return \Hoa\Compiler\Llk\TreeNode
|
|
*/
|
|
public function getChild($i)
|
|
{
|
|
return
|
|
true === $this->childExists($i)
|
|
? $this->_children[$i]
|
|
: null;
|
|
}
|
|
|
|
/**
|
|
* Get children.
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getChildren()
|
|
{
|
|
return $this->_children;
|
|
}
|
|
|
|
/**
|
|
* Get number of children.
|
|
*
|
|
* @return int
|
|
*/
|
|
public function getChildrenNumber()
|
|
{
|
|
return count($this->_children);
|
|
}
|
|
|
|
/**
|
|
* Check if a child exists.
|
|
*
|
|
* @param int $i Index.
|
|
* @return bool
|
|
*/
|
|
public function childExists($i)
|
|
{
|
|
return array_key_exists($i, $this->_children);
|
|
}
|
|
|
|
/**
|
|
* Set parent.
|
|
*
|
|
* @param \Hoa\Compiler\Llk\TreeNode $parent Parent.
|
|
* @return \Hoa\Compiler\Llk\TreeNode
|
|
*/
|
|
public function setParent(TreeNode $parent)
|
|
{
|
|
$old = $this->_parent;
|
|
$this->_parent = $parent;
|
|
|
|
return $old;
|
|
}
|
|
|
|
/**
|
|
* Get parent.
|
|
*
|
|
* @return \Hoa\Compiler\Llk\TreeNode
|
|
*/
|
|
public function getParent()
|
|
{
|
|
return $this->_parent;
|
|
}
|
|
|
|
/**
|
|
* Get data.
|
|
*
|
|
* @return array
|
|
*/
|
|
public function &getData()
|
|
{
|
|
return $this->_data;
|
|
}
|
|
|
|
/**
|
|
* Accept a visitor.
|
|
*
|
|
* @param \Hoa\Visitor\Visit $visitor Visitor.
|
|
* @param mixed &$handle Handle (reference).
|
|
* @param mixed $eldnah Handle (no reference).
|
|
* @return mixed
|
|
*/
|
|
public function accept(
|
|
Visitor\Visit $visitor,
|
|
&$handle = null,
|
|
$eldnah = null
|
|
) {
|
|
return $visitor->visit($this, $handle, $eldnah);
|
|
}
|
|
|
|
/**
|
|
* Remove circular reference to the parent (help the garbage collector).
|
|
*
|
|
* @return void
|
|
*/
|
|
public function __destruct()
|
|
{
|
|
unset($this->_parent);
|
|
|
|
return;
|
|
}
|
|
}
|