HOME


Mini Shell 1.0
DIR: /home/dhnidqcz/journal.pragmaticsng.org/lib__47455f6/pkp/classes/db/
Upload File :
Current File : //home/dhnidqcz/journal.pragmaticsng.org/lib__47455f6/pkp/classes/db/DAOResultIterator.inc.php
<?php

/**
 * @file classes/db/DAOResultIterator.inc.php
 *
 * Copyright (c) 2014-2021 Simon Fraser University
 * Copyright (c) 2000-2021 John Willinsky
 * Distributed under the GNU GPL v3. For full terms see the file docs/COPYING.
 *
 * @class DAOResultIterator
 * @ingroup db
 *
 * @brief Wrapper around a DAOResultFactory providing a proper PHP Iterator implementation
 */


class DAOResultIterator implements Iterator, Countable {
	/** @var DAOResultFactory */
	var $_resultFactory;

	/** @var DataObject Current return value data object. */
	var $_current = null;

	/** @var $_i int 0-based index of current data object. */
	var $_i = 0;

	/**
	 * Create an Iterator for the specified DAOResultFactory.
	 * @param $itemIterator ItemIterator
	 */
	public function __construct($resultFactory) {
		$this->_resultFactory = $resultFactory;
		$this->_current = $this->_resultFactory->next();
	}

	/**
	 * @copydoc Iterator::current
	 */
	public function current() {
		return $this->_current;
	}

	/**
	 * Return the 0-based index for the current object.
	 * Note that this is NOT the DataObject's ID -- for that, call
	 * getId() on the current element.
	 * @return int|null
	 */
	public function key() {
		if (!$this->_current) return null;
		return $this->_i;
		return $this->_current->getId();
	}

	/**
	 * @copydoc Iterator::next()
	 */
	public function next() {
		$this->_current = $this->_resultFactory->next();
		$this->_i++;
	}

	/**
	 * Rewind the DAOResultFactory to the begining. WARNING that this
	 * operation is not arbitrarily supported -- it can only be called
	 * before the first call to `next()`.
	 */
	public function rewind() {
		if ($this->_i != 0) throw new Exception('DAOResultIterator currently does not support rewind() once iteration has started.');
	}

	/**
	 * @copydoc Iterator::valid()
	 */
	public function valid() {
		return ($this->_current !== null);
	}

	/**
	 * @copydoc Countable::count()
	 */
	public function count() {
		return $this->_resultFactory->getCount();
	}
}