Annotation of embedaddon/php/ext/spl/internal/recursivearrayiterator.inc, revision 1.1

1.1     ! misho       1: <?php
        !             2: 
        !             3: /** @file recursivearrayiterator.inc
        !             4:  * @ingroup Examples
        !             5:  * @brief class RecursiveArrayIterator
        !             6:  * @author  Marcus Boerger
        !             7:  * @date    2003 - 2009
        !             8:  *
        !             9:  * SPL - Standard PHP Library
        !            10:  */
        !            11: 
        !            12: /** @ingroup SPL
        !            13:  * @brief   A recursive array iterator
        !            14:  * @author  Marcus Boerger
        !            15:  * @version 1.0
        !            16:  * @since PHP 5.1
        !            17:  *
        !            18:  * Passes the RecursiveIterator interface to the inner Iterator and provides
        !            19:  * the same functionality as FilterIterator. This allows you to skip parents
        !            20:  * and all their childs before loading them all. You need to care about
        !            21:  * function getChildren() because it may not always suit your needs. The 
        !            22:  * builtin behavior uses reflection to return a new instance of the exact same
        !            23:  * class it is called from. That is you extend RecursiveFilterIterator and
        !            24:  * getChildren() will create instance of that class. The problem is that doing
        !            25:  * this does not transport any state or control information of your accept()
        !            26:  * implementation to the new instance. To overcome this problem you might 
        !            27:  * need to overwrite getChildren(), call this implementation and pass the
        !            28:  * control vaules manually.
        !            29:  */
        !            30: class RecursiveArrayIterator extends ArrayIterator implements RecursiveIterator
        !            31: {
        !            32:        /** @return whether the current element has children
        !            33:         */
        !            34:        function hasChildren()
        !            35:        {
        !            36:                return is_array($this->current());
        !            37:        }
        !            38: 
        !            39:        /** @return an iterator for the current elements children
        !            40:         *
        !            41:         * @note the returned iterator will be of the same class as $this
        !            42:         */
        !            43:        function getChildren()
        !            44:        {
        !            45:                if ($this->current() instanceof self)
        !            46:                {
        !            47:                        return $this->current();
        !            48:                }
        !            49:                if (empty($this->ref))
        !            50:                {
        !            51:                        $this->ref = new ReflectionClass($this);
        !            52:                }
        !            53:                return $this->ref->newInstance($this->current());
        !            54:        }
        !            55:        
        !            56:        private $ref;
        !            57: }
        !            58: 
        !            59: ?>

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>