Inheritance diagram for RecursiveIteratorIterator:


Public Member Functions | |
| __construct (RecursiveIterator $it, $mode=self::LEAVES_ONLY, $flags=0) | |
| beginChildren () | |
| callGetChildren () | |
| callHasChildren () | |
| current () | |
| endChildren () | |
| getDepth () | |
| getInnerIterator () | |
| getSubIterator ($level=NULL) | |
| key () | |
| next () | |
| nextElement () | |
| rewind () | |
| valid () | |
Public Attributes | |
| const | CATCH_GET_CHILD = 0x00000002 |
| const | CHILD_FIRST = 2 |
| const | LEAVES_ONLY = 0 |
| const | SELF_FIRST = 1 |
Private Member Functions | |
| callNextElement ($after_move) | |
Private Attributes | |
| $ait = array() | |
| $count = 0 | |
| $flags = 0 | |
| $mode = self::LEAVES_ONLY | |
Definition at line 22 of file recursiveiteratoriterator.inc.
| RecursiveIteratorIterator::__construct | ( | RecursiveIterator $ | it, | |
| $ | mode = self::LEAVES_ONLY, |
|||
| $ | flags = 0 | |||
| ) |
Construct from RecursiveIterator.
| it | RecursiveIterator to iterate | |
| mode | Operation mode (one of):
| |
| flags | Control flags, zero or any combination of the following (since PHP 5.1).
|
Definition at line 53 of file recursiveiteratoriterator.inc.
References $flags, $it, and $mode.
Referenced by DirectoryGraphIterator::__construct().
| RecursiveIteratorIterator::beginChildren | ( | ) |
Called right after calling getChildren() and its rewind().
Definition at line 201 of file recursiveiteratoriterator.inc.
Referenced by next().
| RecursiveIteratorIterator::callGetChildren | ( | ) |
Definition at line 193 of file recursiveiteratoriterator.inc.
Referenced by next().
| RecursiveIteratorIterator::callHasChildren | ( | ) |
Definition at line 185 of file recursiveiteratoriterator.inc.
Referenced by callNextElement(), and next().
| RecursiveIteratorIterator::callNextElement | ( | $ | after_move | ) | [private] |
Definition at line 213 of file recursiveiteratoriterator.inc.
References callHasChildren(), nextElement(), and valid().
Referenced by next(), and rewind().
00214 { 00215 if ($this->valid()) 00216 { 00217 if ($after_move) 00218 { 00219 if (($this->mode == self::SELF_FIRST && $this->callHasChildren()) 00220 || $this->mode == self::LEAVES_ONLY) 00221 $this->nextElement(); 00222 } 00223 else 00224 { 00225 $this->nextElement(); 00226 } 00227 } 00228 }
Here is the call graph for this function:

| RecursiveIteratorIterator::current | ( | ) |
Implements Iterator.
Reimplemented in DirectoryTreeIterator, and RecursiveTreeIterator.
Definition at line 99 of file recursiveiteratoriterator.inc.
References $it.
| RecursiveIteratorIterator::endChildren | ( | ) |
Called after current child iterator is invalid and right before it gets destructed.
Reimplemented in RecursiveCompareDualIterator.
Definition at line 209 of file recursiveiteratoriterator.inc.
Referenced by next(), rewind(), and valid().
| RecursiveIteratorIterator::getDepth | ( | ) |
Definition at line 177 of file recursiveiteratoriterator.inc.
Referenced by DirectoryTreeIterator::current(), and RecursiveTreeIterator::getPrefix().
| RecursiveIteratorIterator::getInnerIterator | ( | ) |
Implements OuterIterator.
Definition at line 170 of file recursiveiteratoriterator.inc.
Referenced by RecursiveCompareDualIterator::areEqual(), RecursiveCompareDualIterator::areIdentical(), and RecursiveCompareDualIterator::endChildren().
| RecursiveIteratorIterator::getSubIterator | ( | $ | level = NULL |
) |
Definition at line 159 of file recursiveiteratoriterator.inc.
Referenced by RecursiveTreeIterator::__call(), DirectoryTreeIterator::__call(), DirectoryTreeIterator::current(), and RecursiveTreeIterator::getPrefix().
00160 { 00161 if (is_null($level)) { 00162 $level = $this->count; 00163 } 00164 return @$this->ait[$level]; 00165 }
| RecursiveIteratorIterator::key | ( | ) |
Implements Iterator.
Reimplemented in RecursiveTreeIterator.
Definition at line 91 of file recursiveiteratoriterator.inc.
References $it.
| RecursiveIteratorIterator::next | ( | ) |
Forward to next element.
Implements Iterator.
Definition at line 107 of file recursiveiteratoriterator.inc.
References $it, beginChildren(), callGetChildren(), callHasChildren(), callNextElement(), endChildren(), and valid().
00108 { 00109 while ($this->count) { 00110 $it = $this->ait[$this->count]; 00111 if ($it->valid()) { 00112 if (!$it->recursed && callHasChildren()) { 00113 $it->recursed = true; 00114 try 00115 { 00116 $sub = callGetChildren(); 00117 } 00118 catch (Exception $e) 00119 { 00120 if (!($this->flags & self::CATCH_GET_CHILD)) 00121 { 00122 throw $e; 00123 } 00124 $it->next(); 00125 continue; 00126 } 00127 $sub->recursed = false; 00128 $sub->rewind(); 00129 if ($sub->valid()) { 00130 $this->ait[++$this->count] = $sub; 00131 if (!$sub instanceof RecursiveIterator) { 00132 throw new Exception(get_class($sub).'::getChildren() must return an object that implements RecursiveIterator'); 00133 } 00134 $this->beginChildren(); 00135 return; 00136 } 00137 unset($sub); 00138 } 00139 $it->next(); 00140 $it->recursed = false; 00141 if ($it->valid()) { 00142 return; 00143 } 00144 $it->recursed = false; 00145 } 00146 if ($this->count) { 00147 unset($this->ait[$this->count--]); 00148 $it = $this->ait[$this->count]; 00149 $this->endChildren(); 00150 callNextElement(false); 00151 } 00152 } 00153 callNextElement(true); 00154 }
Here is the call graph for this function:

| RecursiveIteratorIterator::nextElement | ( | ) |
Called when the next element is available.
Definition at line 232 of file recursiveiteratoriterator.inc.
Referenced by callNextElement().
| RecursiveIteratorIterator::rewind | ( | ) |
Rewind to top iterator as set in constructor.
Implements Iterator.
Reimplemented in RecursiveCompareDualIterator.
Definition at line 62 of file recursiveiteratoriterator.inc.
References callNextElement(), and endChildren().
00063 { 00064 while ($this->count) { 00065 unset($this->ait[$this->count--]); 00066 $this->endChildren(); 00067 } 00068 $this->ait[0]->rewind(); 00069 $this->ait[0]->recursed = false; 00070 callNextElement(true); 00071 }
Here is the call graph for this function:

| RecursiveIteratorIterator::valid | ( | ) |
Implements Iterator.
Definition at line 75 of file recursiveiteratoriterator.inc.
References $count, $it, and endChildren().
Referenced by callNextElement(), and next().
00076 { 00077 $count = $this->count; 00078 while ($count) { 00079 $it = $this->ait[$count]; 00080 if ($it->valid()) { 00081 return true; 00082 } 00083 $count--; 00084 $this->endChildren(); 00085 } 00086 return false; 00087 }
Here is the call graph for this function:

RecursiveIteratorIterator::$ait = array() [private] |
Definition at line 35 of file recursiveiteratoriterator.inc.
RecursiveIteratorIterator::$count = 0 [private] |
RecursiveIteratorIterator::$flags = 0 [private] |
RecursiveIteratorIterator::$mode = self::LEAVES_ONLY [private] |
Definition at line 37 of file recursiveiteratoriterator.inc.
Referenced by RecursiveTreeIterator::__construct(), and __construct().
| const RecursiveIteratorIterator::CATCH_GET_CHILD = 0x00000002 |
Flag: Catches exceptions during getChildren() calls and simply jumps to the next element.
Definition at line 33 of file recursiveiteratoriterator.inc.
| const RecursiveIteratorIterator::CHILD_FIRST = 2 |
Mode: Show all children prior to their parent.
Definition at line 29 of file recursiveiteratoriterator.inc.
| const RecursiveIteratorIterator::LEAVES_ONLY = 0 |
| const RecursiveIteratorIterator::SELF_FIRST = 1 |
Mode: Show parents prior to their children.
Definition at line 27 of file recursiveiteratoriterator.inc.
1.5.2