=1 && $itemsPerPage>=1) { $this->page = $page; } else { $this->page = 1; $this->itemsPerPage = max(count($this->theArray),1); } $this->theArray =& $theArray; $this->count = $totalItems; $this->itemsPerPage = $itemsPerPage; $this->wasEmpty = count($this->theArray)==0; reset($this->theArray); } /** * Factory Method. * Extracts the appropriate page items from the whole array and * calls the constructor. * @param $wholeArray array The whole array of items * @param $rangeInfo int The number of items per page * @return object VirtualArrayIterator */ static function factory($wholeArray, $rangeInfo) { if ($rangeInfo->isValid()) $slicedArray = array_slice($wholeArray, $rangeInfo->getCount() * ($rangeInfo->getPage()-1), $rangeInfo->getCount(), true); return new VirtualArrayIterator($slicedArray, count($wholeArray), $rangeInfo->getPage(), $rangeInfo->getCount()); } /** * Return the next item in the iterator. * @return object */ function &next() { if (!is_array($this->theArray)) { $nullVar = null; return $nullVar; } $value = current($this->theArray); if (next($this->theArray)==null) { $this->theArray = null; } return $value; } /** * Return the next item in the iterator, with key. * @return array (key, value) */ function nextWithKey() { $key = key($this->theArray); $value = $this->next(); return array($key, $value); } /** * Check whether or not this iterator is for the first page of a sequence * @return boolean */ function atFirstPage() { return $this->page==1; } /** * Check whether or not this iterator is for the last page of a sequence * @return boolean */ function atLastPage() { return ($this->page * $this->itemsPerPage) + 1 > $this->count; } /** * Get the page number that this iterator represents * @return int */ function getPage() { return $this->page; } /** * Get the total number of items in the virtual array * @return int */ function getCount() { return $this->count; } /** * Get the total number of pages in the virtual array * @return int */ function getPageCount() { return max(1, ceil($this->count / $this->itemsPerPage)); } /** * Return a boolean indicating whether or not we've reached the end of results * Note: This implementation requires that next() be called before every eof() will * function properly (except the first call). * @return boolean */ function eof() { return (($this->theArray == null) || (count($this->theArray)==0)); } /** * Return a boolean indicating whether or not this iterator was empty from the beginning * @return boolean */ function wasEmpty() { return $this->wasEmpty; } /** * Convert the iterator into an array * @return array */ function &toArray() { return $this->theArray; } /** * A version of array_slice that takes keys into account. * Thanks to pies at sputnik dot pl. * This is made redundant by PHP 5.0.2's updated * array_slice, but we can't assume everyone has that. * FIXME: Reconcile this against the dupe in ArrayItemIterator. * @see http://ca3.php.net/manual/en/function.array-slice.php * @param $array Array * @param $offset int * @param $len int */ function array_slice_key($array, $offset, $len=-1) { if (!is_array($array)) return false; $return = array(); $length = $len >= 0? $len: count($array); $keys = array_slice(array_keys($array), $offset, $length); foreach($keys as $key) { $return[$key] = $array[$key]; } return $return; } } ?>