NAME
Tie::Array::Lazier - Lazier than Tie::Array::Lazy
VERSION
$Id: Lazier.pm,v 0.2 2012/08/09 19:07:27 dankogai Exp $
SYNOPSIS
use Tie::Array::Laier;
# 0..Inf
tie my @a, 'Tie::Array::Laier', [], sub{ $_[1] };
$a[3] = 'three'; # $self->array is [undef, undef, undef, 'three']
print "$_\n" for @a; # 0, 1, 2, 'three', 4 ...
DESCRIPTION
Tie::Array::Lazier is a child class of Tie::Array::Lazy that behaves a lot like its parent except for one thing; It is even lazier.
Instead of filling elements up to $index
, Tie::Array::Lazier It calls $self->maker
when $self->array->[$index]
is undef. Therefore you cannot store undef to the tied array.
EXPORT
None.
FUNCTIONS
Same as Tie::Array::Lazy.
note on $_[0]->index vs $_[1]
While $_[0]->index
is identical to $_[1]
in Tie::Array::Lazy>, these values may disagree in Tie::Array::Lazier Whenever you need the index, use $_[1]
.
# 0..Inf
tie my @a, 'Tie::Array::Lazier', [], sub{ $_[0]->index }; # wrong!
tie my @a, 'Tie::Array::Lazier', [], sub{ $_[1] }; # right!
You can still use $_[0]->index
to find how many elements the internal array holds.
AUTHOR
Dan Kogai, <dankogai at dan.co.jp>
BUGS
See Tie::Array::Lazy.
SUPPORT
See Tie::Array::Lazy.
ACKNOWLEDGEMENTS
See Tie::Array::Lazy.
COPYRIGHT & LICENSE
Copyright 2007 Dan Kogai, all rights reserved.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.