NAME Scalar::Lazy - Yet another lazy evaluation in Perl VERSION $Id: README,v 0.2 2008/06/01 16:29:34 dankogai Exp dankogai $ SYNOPSIS use Scalar::Lazy; my $scalar = lazy { 1 }; print $scalar; # you don't have to force # Y-combinator made easy my $zm = sub { my $f = shift; sub { my $x = shift; lazy { $f->($x->($x)) } }->(sub { my $x = shift; lazy { $f->($x->($x)) } })}; my $fact = $zm->(sub { my $f = shift; sub { my $n = shift; $n < 2 ? 1 : $n * $f->($n - 1) } }); print $fact->(10); # 3628800 DISCUSSION The classical way to implement lazy evaluation in an eager-evaluating languages (including perl, of course) is to wrap the value with a closure: sub delay{ my $value = shift; sub { $value } } my $l = delay(42); Then evaluate the closure whenever you need it. my $v = $l->(); Marking the variable lazy can be easier with prototypes: sub delay(&){ $_[0] } my $l = delay { 42 } But forcing the value is pain in the neck. This module makes it easier by making the value auto-forcing. HOW IT WORKS Check the source. That's what the source is for. There are various CPAN modules that does what this does. But I found others too complicated. Hey, the whole code is only 25 lines long! Nicely fits in a good-old terminal screen. The closest module is Scalar::Defer, a brainchild of Audrey Tang. But I didn't like the way it (ab)?uses namespace. Data::Thunk depends too many modules. And Data::Lazy is overkill. All I needed was auto-forcing and this module does just that. EXPORT "lazy" and "delay". FUNCTIONS lazy lazy { value } is really: Scalar::Lazy->new(sub { value }); delay an alias to "lazy". METHODS new Makes a lazy variable which auto-forces on demand. force You don't really need to call this method (that's the whole point of this module!) but if you want, you can my $l = lazy { 1 }; my $v = $l->force; AUTHOR Dan Kogai, "<dankogai at dan.co.jp>" BUGS Please report any bugs or feature requests to "bug-scalar-lazy at rt.cpan.org", or through the web interface at <http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Scalar-Lazy>. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes. SUPPORT You can find documentation for this module with the perldoc command. perldoc Scalar::Lazy You can also look for information at: * RT: CPAN's request tracker <http://rt.cpan.org/NoAuth/Bugs.html?Dist=Scalar-Lazy> * AnnoCPAN: Annotated CPAN documentation <http://annocpan.org/dist/Scalar-Lazy> * CPAN Ratings <http://cpanratings.perl.org/d/Scalar-Lazy> * Search CPAN <http://search.cpan.org/dist/Scalar-Lazy> ACKNOWLEDGEMENTS Highly inspired by Scalar::Defer by Audrey Tang. COPYRIGHT & LICENSE Copyright 2008 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.