NAME
POE::Component::DirWatch - POE directory watcher
SYNOPSIS
use POE::Component::DirWatch;
POE::Component::DirWatch->spawn(
Alias => 'dirwatch',
Directory => '/some_dir',
Filter => sub { $_[0] =~ /\.gz$/ && -f $_[1] },
Callback => \&some_sub,
PollInterval => 1,
);
DESCRIPTION
POE::Component::DirWatch watches a directory for files. It creates a separate session which invokes a user-supplied callback as soon as it finds a file in the directory.
Its primary intended use is processing a "drop-box" style directory, such as an FTP upload directory.
ARGUMENTS
- Alias
-
The alias for the DirWatch session. Defaults to
dirwatch
if not specified. - Directory
-
The name of the directory to watch. This is a required argument.
- PollInterval
-
The intervals between polls of the directory, in seconds. Default to 1 if not specified.
- Callback
-
A reference to a subroutine that will be called when a matching file is found in the directory.
This subroutine is called with two arguments: the name of the file, and its full pathname. It usually makes most sense to process the file and remove it from the directory.
This is a required argument.
- Filter
-
A reference to a subroutine that will be called for each file in the watched directory. It should return a TRUE value if the file qualifies as found, FALSE if the file is to be ignored.
This subroutine is called with two arguments: the name of the file, and its full pathname.
If not specified, defaults to
sub { -f $_[1] }
.
TODO
Use Win32::ChangeNotify
on Win32 platforms for better performance.
SEE ALSO
POE(3), POE::Component(3)
AUTHOR
Eric Cholet, <cholet@logilune.com>
Thanks to Matt Sergeant for POE insights and bug reports, and David Rigaudiere for Win32 testing.
COPYRIGHT
Copyright 2002 Eric Cholet. All Rights Reserved. This is free software; you may redistribute it and/or modify it under the same terms as Perl itself.