TITLE
Iter -- A PIR-based Iterator Object
DESCRIPTION
An iterator with an object-oriented interface, written in PIR. Currently implemented only for Array type PMCs. Expect Hash support shortly.
SYNOPSIS
load_bytecode 'Iter.pir'
.local pmc iter
iter = new 'Iter'
## initialize the iterator
iter.'start'(your_aggregate)
## advance to the next item in the iterator
iter.'next'()
## check for exhaustion
$I0 = iter.'exhausted'()
if $I0 goto done
## get the value from the iterator
$P0 = iter.'value'()
## alternate interface to advance and get the value
$P0 = iter.'nextval'()
Iter Methods
.'start'(PMC aggregate)
Initialize the iterator. Must pass a PMC aggregate, or an exception is thrown.
.'next'()
Sets the internal .'exhausted'()
Returns true (1) if the iterator is exhausted. Returns false (0) otherwise.
.'value'()
Returns the current value from the iterator. Returns PMCNULL if exhausted.
.'nextval'()
Executes
value attribute to the value of the next item from the iterator. Sets the internal exhausted attribute if the iterator is exhausted.
.'next'(), and returns .'value'().AUTHOR
Jerry Gay a.k.a. particle