NAME
AnyEvent::Inotify::Simple - monitor a directory tree in a non-blocking way
SYNOPSIS
use AnyEvent::Inotify::Simple;
use EV; # or POE, or Event, or ...
my $inotify = AnyEvent::Inotify::Simple->new(
directory => '/tmp/uploads/',
wanted_events => [ qw(create move) ],
event_receiver => sub {
my ($event, $file, $moved_to) = @_;
given($event) {
when('create'){
say "Someone just uploaded $file!"
}
};
},
);
EV::loop;
DESCRIPTION
This module is a wrapper around Linux::Inotify2 that integrates it with an AnyEvent event loop and makes monitoring a directory simple. Provide it with a directory
, event_receiver
(AnyEvent::Inotify::Simple::EventReceiver), and an optional coderef filter
and/or optional array ref wanted_events
, and it will monitor an entire directory tree. If something is added, it will start watching it. If something goes away, it will stop watching it. It also converts IN_MOVE_FROM
and IN_MOVE_TO
into one virtual event.
Someday I will write more, but that's really all that happens!
METHODS
None! Create the object, and it starts working immediately. Destroy the object, and the inotify state and watchers are automatically cleaned up.
REPOSITORY
Forks welcome!
http://github.com/jrockway/anyevent-inotify-simple
AUTHOR
Jonathan Rockway <jrockway@cpan.org>
Current maintainer is Rob N ★ <robn@robn.io>
COPYRIGHT
Copyright 2009 (c) Jonathan Rockway. This module is Free Software. You may redistribute it under the same terms as Perl itself.
1 POD Error
The following errors were encountered while parsing the POD:
- Around line 318:
Non-ASCII character seen before =encoding in '★'. Assuming UTF-8