I'm Newbie - sorry if this is the wrong list!

I'm trying to print this treestructure I've made, but it doesn't seem to
print more than the first level. The
 subtree array of the children is empty, perhaps because I do not
use the correct reference passing?

Thank you for helping me out.
This is the code:
<?php
require('database.php'); // $databaseis defined here $database = new db();
class TreeNode
{
 var $data;  //Database object reference
 var $id;  //Unique ID from the database
 var $subtree; //Array of treenodes that are the children of $currentNode
 var $level;  //Level in the tree. The toplevel = 0  function TreeNode($id,
$data, $level) //Constructor
 {
  $this->id = $id;
  $this->data = $data;
  $this->level = $level;
  $this->subtree = array();
 }  function add($currentNode)
 {
  //This function is used to add a TreeNode, $currentNode to the subtree
  print "parent: ". $this->id ." New node: ". $currentNode->id ."<br>";
  $this->subtree[] = $currentNode;
 }  function output()
 {
  for ($i=0;$i<count($this->subtree);$i++)
  {
   $tree =& $this->subtree[$i];
      if (is_object($tree))
   print "ID: ".$tree->id."<BR>";
      print "Count: ".count($tree->subtree)."<BR>";
      $tree->output();
  } /*  foreach ($this->subtree as $tree) //Skal være en while løkke, da
$tree->subtree er tomt.
  {
      if (is_object($tree))
      print "ID: ".$tree->id."<BR>";
         $tree->output();
  }
*/
 }
} //Initialize
$treetop = new TreeNode(0, 0, -1);  // You have to have a start position
$nodehash = array();    // This is only used to find the parents //Make the
query
$sql = "SELECT * FROM page_table WHERE visible=1 ORDER BY id, title";
$query = new query($database, $sql); while ($obj = $query->getobj())
{
  if($obj->parent_id > 0){ //If the node is not on the toplevel
   $parent =& $nodehash["id_$obj->parent_id"]; //Finds the parent in the
$nodehash
  }
  else
  {
   $parent =& $treetop;   //If the node is on the toplevel then the parent
is $treetop
  }
  $level = $parent->level + 1; //The tree level of $currentNode is of course
one more than the $parent (level
 is not stored in db)  //when we have found the level of $currentnode we are
ready to construct the
 $currentNode using the parameters
 from the database and the $level
  $currentNode = new TreeNode($obj->id, $obj, $level);
  $nodehash["id_$obj->id"] = $currentNode; //Insert the $currentNode into
the $nodehash so we can find it again
 if it has any children
  $parent->add($currentNode); //Use the add function of the $parent to put
$currentNode into $parent's subtree
}

//Something has to be printed out...
$treetop->output();
?>



-- 
PHP General Mailing List (http://www.php.net/)
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]
To contact the list administrators, e-mail: [EMAIL PROTECTED]

Reply via email to