Tie::Dir - class definition for reading directories via a tied hash |
Tie::Dir - class definition for reading directories via a tied hash
use Tie::Dir qw(DIR_UNLINK);
# Both of these produce identical results #(ie %hash is tied) tie %hash, Tie::Dir, ".", DIR_UNLINK; new Tie::Dir \%hash, ".", DIR_UNLINK;
# This creates a reference to a hash, which is tied. $hash = new Tie::Dir ".";
# All these examples assume that %hash is tied (ie one of the # first two tie methods was used
# itterate through the directory foreach $file ( keys %hash ) { ... }
# Set the access and modification times (touch :-) $hash{SomeFile} = time;
# Obtain stat information of a file @stat = @{$hash{SomeFile}};
# Check if entry exists if(exists $hash{SomeFile}) { ... }
# Delete an entry, only if DIR_UNLINK specified delete $hash{SomeFile};
This module provides a method of reading directories using a hash.
The keys of the hash are the directory entries and the values are a
reference to an array which holds the result of stat
being called
on the entry.
The access and modification times of an entry can be changed by assigning to an element of the hash. If a single number is assigned then the access and modification times will both be set to the same value, alternatively the access and modification times may be set separetly by passing a reference to an array with 2 entries, the first being the access time and the second being the modification time.
hashref
to the directory dirname
.
If hashref
is omitted then new
returns a reference to a hash which
hash been tied, otherwise it returns the result of tie
The possible options are:
unlink
to be called on the
corresponding file
Graham Barr <bodg@tiuk.ti.com>, from a quick hack posted by Kenneth Albanowski <kjahds@kjahds.com> to the perl5-porters mailing list based on a neat idea by Ilya Zakharevich.
Tie::Dir - class definition for reading directories via a tied hash |