| Server IP : 127.0.1.1 / Your IP : 216.73.216.83 Web Server : Apache/2.4.58 (Ubuntu) System : Linux nepub 6.8.0-88-generic #89-Ubuntu SMP PREEMPT_DYNAMIC Sat Oct 11 01:02:46 UTC 2025 x86_64 User : root ( 0) PHP Version : 8.2.30 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : OFF Directory : /var/www/html/public_html/lib/pkp/classes/db/ |
Upload File : |
<?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
*/
#[\ReturnTypeWillChange]
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
*/
#[\ReturnTypeWillChange]
public function key() {
if (!$this->_current) return null;
return $this->_i;
return $this->_current->getId();
}
/**
* @copydoc Iterator::next()
*/
#[\ReturnTypeWillChange]
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()`.
*/
#[\ReturnTypeWillChange]
public function rewind() {
if ($this->_i != 0) throw new Exception('DAOResultIterator currently does not support rewind() once iteration has started.');
}
/**
* @copydoc Iterator::valid()
*/
#[\ReturnTypeWillChange]
public function valid() {
return ($this->_current !== null);
}
/**
* @copydoc Countable::count()
*/
#[\ReturnTypeWillChange]
public function count() {
return $this->_resultFactory->getCount();
}
}