php.net |  support |  documentation |  report a bug |  advanced search |  search howto |  statistics |  random bug |  login
Bug #42279 LimitIterator doesn't follow Iterator contract
Submitted: 2007-08-12 15:13 UTC Modified: 2007-08-12 15:24 UTC
From: michiel at worthit dot nl Assigned:
Status: Not a bug Package: SPL related
PHP Version: 5CVS-2007-08-12 (snap) OS: Any
Private report: No CVE-ID: None
Welcome back! If you're the original bug submitter, here's where you can edit the bug or add additional notes.
If you forgot your password, you can retrieve your password here.
Password:
Status:
Package:
Bug Type:
Summary:
From: michiel at worthit dot nl
New email:
PHP Version: OS:

 

 [2007-08-12 15:13 UTC] michiel at worthit dot nl
Description:
------------
The LimitIterator doesn't seem to follow the Iterator contract: It's not possible to iterate using the Iterator methods.

Reproduce code:
---------------
$limitIterator = new LimitIterator(new ArrayIterator(array('foo')));

$arrayIterator = new ArrayIterator(array('foo'));

$limitItValue = $limitIterator->current();
$arrayItValue = $arrayIterator->current();

Expected result:
----------------
$limitItValue and $arrayItValue to be equal (both 'foo')

Actual result:
--------------
$limitItValue ends up being NULL, while $arrayItValue has the expected value 'foo'.

Patches

Pull Requests

History

AllCommentsChangesGit/SVN commitsRelated reports
 [2007-08-12 15:24 UTC] johannes@php.net
Thank you for taking the time to write to us, but this is not
a bug. Please double-check the documentation available at
http://www.php.net/manual/ and the instructions on how to report
a bug at http://bugs.php.net/how-to-report.php

You have to call rewind() before accessing current(), without calling rewind() the current value is undefined.
 
PHP Copyright © 2001-2025 The PHP Group
All rights reserved.
Last updated: Thu Jul 03 16:01:36 2025 UTC