]> granicus.if.org Git - php/commitdiff
- MFH Update example
authorMarcus Boerger <helly@php.net>
Mon, 3 Oct 2005 13:36:18 +0000 (13:36 +0000)
committerMarcus Boerger <helly@php.net>
Mon, 3 Oct 2005 13:36:18 +0000 (13:36 +0000)
ext/spl/examples/recursivetreeiterator.inc

index 169b3a802232f6d0dd41996f9e586117f9238323..ab526e4ca1e73b329eda664f7cc540af8cdbc54e 100755 (executable)
@@ -26,17 +26,61 @@ class RecursiveTreeIterator extends RecursiveIteratorIterator
                $this->callToString = (bool)($cit_flags & CachingIterator::CALL_TOSTRING);
        }
 
+       /** @return prefix used if $level < depth and hasNext($level) == true
+        */
+       function getPrefix1()
+       {
+               return '| ';
+       }
+
+       /** @return prefix used if $level < depth and hasNext($level) == false
+        */
+       function getPrefix2()
+       {
+               return '  ';
+       }
+
+       /** @return prefix used if $level == depth and hasNext($level) == true
+        */
+       function getPrefix3()
+       {
+               return '|-';
+       }
+
+       /** @return prefix used if $level == depth and hasNext($level) == false
+        */
+       function getPrefix4()
+       {
+               return '\-';
+       }
+
+       function getPrefix($level)
+       {
+               if ($level < 0 || $level > $this->getDepth())
+               {
+                       throw new OutOfBoundsException('Parameter $level must be >= 0 and <= depth');
+               }
+               if ($level < $this->getDepth())
+               {
+                       return $this->getSubIterator($level)->hasNext() ? $this->getPrefix1() : $this->getPrefix2();
+               }
+               else
+               {
+                       return $this->getSubIterator($level)->hasNext() ? $this->getPrefix3() : $this->getPrefix4();
+               }
+       }
+
        /** @return the current element prefixed with ASCII graphics
         */
        function current()
        {
                $tree = '';
-               for ($l=0; $l < $this->getDepth(); $l++) {
-                       $tree .= $this->getSubIterator($l)->hasNext() ? '| ' : '  ';
+               for ($l=0; $l <= $this->getDepth(); $l++)
+               {
+                       $tree .= $this->getPrefix($l);
                }
                
-               return $tree . ($this->getSubIterator($l)->hasNext() ? '|-' : '\-')
-                      . ($this->callToString ? $this->getSubIterator($l)->__toString() : $this->getSubIterator($l)->current());
+               return $tree . ($this->callToString ? $this->__toString() : parent::current());
        }
 
        /** Aggregates the inner iterator