From: Marcus Boerger Date: Thu, 13 Oct 2005 19:45:29 +0000 (+0000) Subject: - Add ability to bypass key() surrounding and make that default X-Git-Tag: RELEASE_0_9_1~118 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=533b61cf3b700a63f638b9618f06c39d83664959;p=php - Add ability to bypass key() surrounding and make that default --- diff --git a/ext/spl/examples/recursivetreeiterator.inc b/ext/spl/examples/recursivetreeiterator.inc index 2d2210e704..42d217fa76 100755 --- a/ext/spl/examples/recursivetreeiterator.inc +++ b/ext/spl/examples/recursivetreeiterator.inc @@ -19,6 +19,7 @@ class RecursiveTreeIterator extends RecursiveIteratorIterator { const BYPASS_CURRENT = 0x00000004; + const BYPASS_KEY = 0x00000008; private $rit_flags; @@ -28,7 +29,7 @@ class RecursiveTreeIterator extends RecursiveIteratorIterator * @param cit_flags flags passed to RecursiveCachingIterator (for hasNext) * @param mode mode passed to RecursiveIteratoIterator (parent) */ - function __construct(RecursiveIterator $it, $rit_flags = 0, $cit_flags = CachingIterator::CATCH_GET_CHILD, $mode = self::SELF_FIRST) + function __construct(RecursiveIterator $it, $rit_flags = self::BYPASS_KEY, $cit_flags = CachingIterator::CATCH_GET_CHILD, $mode = self::SELF_FIRST) { parent::__construct(new RecursiveCachingIterator($it, $cit_flags), $mode, $rit_flags); $this->rit_flags = $rit_flags; @@ -91,7 +92,14 @@ class RecursiveTreeIterator extends RecursiveIteratorIterator */ function key() { - return $this->getPrefix() . parent::key() . $this->getPostfix(); + if ($this->rit_flags & self::BYPASS_KEY) + { + return parent::key(); + } + else + { + return $this->getPrefix() . parent::key() . $this->getPostfix(); + } } /** Aggregates the inner iterator