That's really the same thing as just having the file be the enclosing scope. It would be different if this were for a subroutine that returned the list.
sub get_dirlist { my $dir_to_scan = shift; my @dirlist; my $wanted = sub { return unless -d $_; push(@dirlist,$File::Find::name); } find( $wanted, $dir_to_scan ); return @dirlist; }
The anonymous subroutine attached to $wanted is compiled only once, but gets a fresh copy of @dirlist for each invokation. Contrast that to this, which would continue to add to @dirlist each time the get_dirlist function was called and return a longer and longer array each time:
my @dirlist; sub wanted { return unless -d $_; push(@dirlist,$File::Find::name); } sub get_dirlist { my $dir_to_scan = shift; find( \&wanted, $dir_to_scan ); return @dirlist; }
-xdg
Code written by xdg and posted on PerlMonks is public domain. It is provided as is with no warranties, express or implied, of any kind. Posted code may not have been tested. Use of posted code is at your own risk.
In reply to Re^2: Return values, Closure Vars from File::Find &wanted subs?
by xdg
in thread Return values, Closure Vars from File::Find &wanted subs?
by Subliminal Kid
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |