NAME
Tie::Array::File::LazyRead - Read a file record by record using tied array and for()
VERSION
This document describes version 0.001 of Tie::Array::File::LazyRead (from Perl distribution Tie-Array-File-LazyRead), released on 2019-04-16.
SYNOPSIS
Given FILENAME.txt containing:
line1
line2
line3
Then this Perl script:
use Tie::Array::File::LazyRead;
tie my @ary, 'Tie::Array::File::LazyRead', 'FILENAME.txt', {accumulate=>1}; # default for accumulate is 0
for my $line (@ary) {
print $line;
}
will print:
line1
line2
line3
and @ary
containing:
["line1", "line2", "line3"]
If accumulate
is set to 0 (the default), @ary
will contain:
[undef, undef, "line3"]
(i.e. only the last element/line will be remembered.
DESCRIPTION
EXPERIMENTAL, PROOF-OF-CONCEPT.
When for()
is given a tied array:
for (@tied_array) {
...
}
it will invoke FETCHSIZE
on the tied array to find out the size, then FETCH(0), then FETCHSIZE() again, then FETCH(1), and so on. In other words, FETCHSIZE
is called on each iteration. This makes it possible to only fetch new data in FETCHSIZE
instead of FETCH
.
Without using for()
:
tie my @ary, 'Tie::Array::File::LazyRead', 'FILENAME.txt';
print $ary[0];
will not print anything, and the first line of the file is not fetched. To fetch one more line, you need to do:
my $size = @ary;
# then
print $ary[0];
and so on.
HOMEPAGE
Please visit the project's homepage at https://metacpan.org/release/Tie-Array-File-LazyRead.
SOURCE
Source repository is at https://github.com/perlancar/perl-Tie-Array-File-LazyRead.
BUGS
Please report any bugs or feature requests on the bugtracker website https://rt.cpan.org/Public/Dist/Display.html?Name=Tie-Array-File-LazyRead
When submitting a bug or request, please include a test-file or a patch to an existing test-file that illustrates the bug or desired feature.
SEE ALSO
AUTHOR
perlancar <perlancar@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2019 by perlancar@cpan.org.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.