NAME Linux::Inotify - Classes for supporting inotify in Linux Kernel >= 2.6.13 VERSION version 0.06 DESCRIPTION Linux::Inotify supports the new inotify interface of Linux which is a replacement of dnotify. Beside the class Linux::Inotify there two helper classes -- Linux::Inotify::Watch and Linux::Inotify::Event. class Linux::Inotify The following code use Linux::Inotify; my $notifier = Linux::Inotify->new(); returns a new notifier. my $watch = $notifier->add_watch('filename', Linux::Inotify::MASK); adds a watch to filename (see below), where MASK is one of ACCESS, MODIFY, ATTRIB, CLOSE_WRITE, CLOSE_NOWRITE, OPEN, MOVED_FROM, MOVED_TO, CREATE, DELETE, DELETE_SELF, UNMOUNT, Q_OVERFLOW, IGNORED, ISDIR, ONESHOT, CLOSE, MOVE or ALL_EVENTS. my @events = $notifier->read(); reads and decodes all available data and returns an array of Linux::Inotify::Event objects (see below). $notifier->close(); destroys the notifier and closes the associated file descriptor. class Linux::Inotify::Watch The constructor new is usually not called directly but via the add_watch method of the notifier. An alternative constructor. my $watch_clone = $watch->clone('filename'); creates an new watch for filename but shares the same $notifier and MASK. This is indirectly used for recursing into subdirectories (see below). The destructor $watch->remove() destroys the watch safely. It does not matter if the kernel has already removed the watch itself, which may happen when the watched object has been deleted. class Linux::Inotify::Event The constructor is not called directly but through the read method of Linux::Inotify that returns an array of event objects. An Linux::Inotify::Event object has some interesting data members: mask, cookie and name. The method $event->fullname(); returns the full name of the file or directory not only the name relative to the watch like the name member does contain. $event->print(); prints the event to stdout in a human readable form. my $new_watch = $event->add_watch(); creates a new watch for the file/directory of the event and shares the notifier and MASK of the original watch, that has generated the event. That is useful for recursing into subdirectories. AUTHOR Original author: Torsten Werner Current maintainer: Graham Ollis <plicease@cpan.org> COPYRIGHT AND LICENSE This software is copyright (c) 2018-2022 by Torsten Werner <twerner@debian.org>. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.