Provided by: libfile-modified-perl_0.07-3_all bug

NAME

       File::Modified - checks intelligently if files have changed

SYNOPSIS

         use strict;
         use File::Modified;

         my $d = File::Modified->new(files=>['Import.cfg','Export.cfg']);

         while (1) {
           my (@changes) = $d->changed;

           if (@changes) {
             print "$_ was changed\n" for @changes;
             $d->update();
           };
           sleep 60;
         };

       Second example - a script that knows when any of its modules have changed :

         use File::Modified;
         my $files = File::Modified->new(files=>[values %INC, $0]);

         # We want to restart when any module was changed
         exec $0, @ARGV if $files->changed();

DESCRIPTION

       The Modified module is intended as a simple method for programs to detect whether
       configuration files (or modules they rely on) have changed. There are currently two
       methods of change detection implemented, "mtime" and "MD5".  The "MD5" method will fall
       back to use timestamps if the "Digest::MD5" module cannot be loaded.

       There is another module, File::Signature, which has many similar features, so if this
       module doesn't do what you need, maybe File::Signature does. There also is quite some
       overlap between the two modules, code wise.

       new %ARGS
           Creates a new instance. The %ARGS hash has two possible keys, "Method", which denotes
           the method used for checking as default, and "Files", which takes an array reference
           to the filenames to watch.

       add filename, method
           Adds a new file to watch. "method" is the method (or rather, the subclass of
           "File::Modified::Signature") to use to determine whether a file has changed or not.
           The result is either the "File::Modified::Signature" subclass or undef if an error
           occurred.

       addfile LIST
           Adds a list of files to watch. The method used for watching is the default method as
           set in the constructor. The result is a list of "File::Modified::Signature"
           subclasses.

       update
           Updates all signatures to the current state. All pending changes are discarded.

       changed
           Returns a list of the filenames whose files did change since the construction or the
           last call to "update" (whichever last occurred).

   Signatures
       The module also creates a new namespace "File::Signature", which sometime will evolve into
       its own module in its own file. A file signature is most likely of little interest to you;
       the only time you might want to access the signature directly is to store the signature in
       a file for persistence and easy comparision whether an index database is current with the
       actual data.

       The interface is settled, there are two methods, "as_scalar" and "from_scalar", that you
       use to freeze and thaw the signatures. The implementation of these methods is very frugal,
       there are no provisions made against filenames that contain weird characters like "\n" or
       "|" (the pipe bar), both will be likely to mess up your one-line-per-file database. An
       interesting method could be to URL-encode all filenames, but I will visit this topic in
       the next release. Also, complex (that is, non-scalar) signatures are handled rather
       ungraceful at the moment.

       Currently, I'm planning to use Text::Quote as a quoting mechanism to protect against
       multiline filenames.

   Adding new methods for signatures
       Adding a new signature method is as simple as creating a new subclass of
       "File::Signature". See "File::Signature::Checksum" for a simple example. There is one
       point of laziness in the implementation of "File::Signature", the "check" method can only
       compare strings instead of arbitrary structures (yes, there ARE things that are easier in
       Python than in Perl). "File::Signature::Digest" is a wrapper for Gisle Aas' Digest module
       and allows you to use any module below the "Digest" namespace as a signature, for example
       "File::Signature::MD5" and "File::Signature::SHA1".

   TODO
       * Make the simple persistence solution for the signatures better using Text::Quote.

       * Allow complex structures for the signatures.

       * Document "File::Modified::Signature" or put it down into another namespace.

       * Extract the "File::Modified::Signature" subclasses out into their own file.

       * Create an easy option to watch a whole directory tree.

   EXPORT
       None by default.

   COPYRIGHT AND LICENSE
       This library is free software; you can redistribute it and/or modify it under the same
       terms as Perl itself.

       Copyright (C) 2002 Max Maischein

AUTHOR

       Max Maischein, <corion@cpan.org>

       Please contact me if you find bugs or otherwise improve the module. More tests are also
       very welcome !

SEE ALSO

       perl,Digest::MD5,Digest, File::Signature.