NAME
POEx::DirNotify - dnotify interface for POE
SYNOPSIS
use strict;
use POE;
use POEx::DirNotify;
POEx::DirNotify->new( alias=>'notify' );
POE::Session->create(
package_states => [
'main' => [ qw(_start notification) ],
],
);
$poe_kernel->run();
exit 0;
sub _start {
my( $kernel, $heap ) = @_[ KERNEL, HEAP ];
$kernel->post( 'notify' => monitor => {
path => '.',
event => 'notification',
args => [ $args ]
} );
return;
}
sub notification {
my( $kernel, $hashref, $args ) = @_[ KERNEL, ARG0, ARG1];
print "Something changed in $hashref->{path}\n";
$kernel->post( notify => 'shutdown' );
return;
}
DESCRIPTION
POEx::DirNotify is a simple interface to the Linux file and directory change notification interface, also called dnotify
.
It can monitor an existing directory for new files, deleted files, new directories and more. It can not detect the monitored directory being deleted. This is a limitation of the underlying dnotify.
METHODS
spawn
POEx::Session->spawn( %options );
Takes a number of arguments, all of which are optional.
- alias
-
The session alias to register with the kernel. Defaults to
dnotify
. - options
-
A hashref of POE::Session options that are passed to the component's session creator.
EVENTS
monitor
$poe_kernel->call( dnotify => 'monitor', $arg );
Starts monitoring the specified path for the specified types of changes.
Accepts one argument, a hashref containing the following keys:
- path
-
The filesystem path to the directory to be monitored. Mandatory.
- event
-
The name of the event handler in the current session to post changes back to. Mandatory.
- args
-
An arrayref of arguments that will be passed to the event handler.
unmonitor
$poe_kernel->call( dnotify => 'unmonitor', $arg );
Ends monitoring of the specified path for the current session.
Accepts one argument, a hashref containing the following keys:
- path
-
The filesystem path to the directory to be unmonitored. Mandatory.
shutdown
$poe_kernel->call( dnotify => 'shutdown' );
# OR
$poe_kernel->signal( $poe_kernel => 'shutdown' );
Shuts down the component gracefully. All monitored paths will be closed. Has no arguments.
SEE ALSO
This module's API was heavily inspired by POE::Component::Win32::ChangeNotify.
AUTHOR
Philip Gwyn, <gwyn -at- cpan.org>
COPYRIGHT AND LICENSE
Copyright (C) 2010 by Philip Gwyn. All rights reserved.
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.8 or, at your option, any later version of Perl 5 you may have available.