mirror of
https://port.numenaute.org/aleajactaest/khanat-opennel-code.git
synced 2024-11-11 17:59:03 +00:00
49 lines
1.3 KiB
PHP
49 lines
1.3 KiB
PHP
|
<?php
|
||
|
abstract class Parentum extends Node {
|
||
|
/*---------------------------
|
||
|
This class allows external access to the child-node list.
|
||
|
Use the NodeIterator to iterate through the list since
|
||
|
the numeric array keys might have gaps due to node removals!
|
||
|
|
||
|
Once init() has been called, an AVLTree is used to support the
|
||
|
functions removeChild() and findChild(). init() must be called
|
||
|
before adding any nodes!
|
||
|
---------------------------*/
|
||
|
protected $nodes;
|
||
|
|
||
|
function Parentum() {
|
||
|
parent::__construct();
|
||
|
$this->nodes = new DLL(); // Doubly Linked List
|
||
|
}
|
||
|
|
||
|
abstract protected function makeChild($args); // overwriteable child generator; allows to define child type (eg.: admin classes that inherit from base class)
|
||
|
|
||
|
function isEmpty() {
|
||
|
return $this->nodes->isEmpty();
|
||
|
}
|
||
|
|
||
|
function addChild($data,$b = null) {
|
||
|
$this->nodes->addNode($data,$b);
|
||
|
}
|
||
|
|
||
|
function removeChild($id) {
|
||
|
$this->nodes->removeNode($id);
|
||
|
}
|
||
|
|
||
|
function getChildByID($id) { // returns a DLL node
|
||
|
return $this->nodes->findNode($id);
|
||
|
}
|
||
|
|
||
|
function getChildDataByID($id) { // returns the actual content of the found DLL node
|
||
|
$tmp = $this->getChildByID($id);
|
||
|
if($tmp != null) {
|
||
|
return $tmp->data;
|
||
|
}
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
function getIterator() {
|
||
|
return $this->nodes->getIterator();
|
||
|
}
|
||
|
}
|
||
|
?>
|