NAME
Module::Generic::Iterator - An Array Iterator Object Class
SYNOPSIS
my $i = Module::Generic::Iterator->new( [qw( Joe John Mary )] );
# or also:
my $a = Module::Generic::Array->new( [qw( Joe John Mary )] );
my $i = $a->iterator;
while( $i->has_next )
{
my $elem = $i->next;
my $value = $elem->value;
# Get the next element relative to our element
printf( "Next value is: %s at offset %d\n", $elem->next, $elem->next->pos );
}
VERSION
v1.1.0
DESCRIPTION
This provides an object oriented array iterator. Each of its elements are Module::Generic::Iterator::Element object
METHODS
new
Provided with an array reference or an Module::Generic::Array object, and this will create a new iterator and return it.
elements
Contains the array elements
eof
Returns true if the position in the iterator has reached the end of the array.
find
Creates a clone of the current array object and returns it.Provided wit an array element and this returns its position in the array starting at 0.
If nothing was found, this returns undef.
first
Returns the first element of the array.
has_next
Returns true if there is another item after the current one.
has_prev
Returns true if there is another item before the current one.
last
Returns the last element of the array.
length
Returns the size of the array, starting from 1, as a Module::Generic::Number object.
next
Returns the next Module::Generic::Iterator::Element object or undef if there are no more element.
pos
Sets or returns the current position in the array.
This is an lvalue method.
$e->pos = 10; # Sets the current position to 10
my $pos = $e->pos; # Returns the current position
prev
Returns the previous Module::Generic::Iterator::Element object or undef if there are no more previous element.
reset
Reset the position inside the array and sets it to 0.
_find_pos
Provided with an item, this returns its position in the array or undef if it is not in the array.
SERIALISATION
Serialisation by CBOR, Sereal and Storable::Improved (or the legacy Storable) is supported by this package. To that effect, the following subroutines are implemented: FREEZE
, THAW
, STORABLE_freeze
and STORABLE_thaw
SEE ALSO
Module::Generic::Iterator::Element, Module::Generic::Array
AUTHOR
Jacques Deguest <jack@deguest.jp>
COPYRIGHT & LICENSE
Copyright (c) 2000-2020 DEGUEST Pte. Ltd.
You can use, copy, modify and redistribute this package and associated files under the same terms as Perl itself.