2012-06-24 12:44:24 +02:00
< ? php
2012-07-08 18:11:25 +02:00
abstract class Parentum extends Node {
2012-06-25 15:03:14 +02:00
/*---------------------------
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 !
2012-07-01 20:04:01 +02:00
Once init () has been called , an AVLTree is used to support the
functions removeChild () and findChild () . init () must be called
before adding any nodes !
2012-06-25 15:03:14 +02:00
---------------------------*/
2012-07-08 18:11:25 +02:00
protected $nodes ;
2012-07-01 20:04:01 +02:00
2012-07-08 18:11:25 +02:00
function Parentum () {
parent :: __construct ();
$this -> nodes = new DLL (); // Doubly Linked List
2012-07-01 20:04:01 +02:00
}
2012-06-25 15:03:14 +02:00
2012-07-01 20:04:01 +02:00
abstract protected function makeChild ( $args ); // overwriteable child generator; allows to define child type (eg.: admin classes that inherit from base class)
2012-06-25 15:03:14 +02:00
2012-07-08 18:11:25 +02:00
function isEmpty () {
return $this -> nodes -> isEmpty ();
2012-06-25 15:03:14 +02:00
}
2012-07-09 19:10:44 +02:00
function addChild ( $data , $b = null ) {
$this -> nodes -> addNode ( $data , $b );
2012-06-25 15:03:14 +02:00
}
2012-07-08 18:11:25 +02:00
function removeChild ( $id ) {
$this -> nodes -> removeNode ( $id );
2012-06-25 15:03:14 +02:00
}
2012-07-08 18:11:25 +02:00
function getChildByID ( $id ) {
return $this -> nodes -> findNode ( $id );
2012-06-25 15:03:14 +02:00
}
2012-07-08 18:11:25 +02:00
function getChildDataByID ( $id ) {
$tmp = $this -> getChildByID ( $id );
if ( $tmp != null ) {
return $tmp -> data ;
2012-06-25 15:03:14 +02:00
}
return null ;
}
2012-07-08 18:11:25 +02:00
function getIterator () {
return $this -> nodes -> getIterator ();
2012-06-25 15:03:14 +02:00
}
2012-06-24 12:44:24 +02:00
}
?>