diff options
author | Eric Wong <e@80x24.org> | 2021-05-14 20:14:47 +0000 |
---|---|---|
committer | Eric Wong <e@80x24.org> | 2021-05-15 05:39:17 +0000 |
commit | 79e274b293a71fb41dd8bf6e9598a8e8a24fed4f (patch) | |
tree | 2847419f054afcd738b12c1a6fd3d130b9a4a3a1 /lib/PublicInbox/DirIdle.pm | |
parent | 671e7f4c9d82b053fba475aaeaa16a94dc3adad2 (diff) | |
download | public-inbox-79e274b293a71fb41dd8bf6e9598a8e8a24fed4f.tar.gz |
We'll treat IN_MOVE_SELF as IN_DELETE_SELF since there doesn't seem to be a reliable way to distinguish them with FakeInotify, nor know the new name with kevent.
Diffstat (limited to 'lib/PublicInbox/DirIdle.pm')
-rw-r--r-- | lib/PublicInbox/DirIdle.pm | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/lib/PublicInbox/DirIdle.pm b/lib/PublicInbox/DirIdle.pm index e53fd9d1..5142d005 100644 --- a/lib/PublicInbox/DirIdle.pm +++ b/lib/PublicInbox/DirIdle.pm @@ -12,17 +12,23 @@ my ($MAIL_IN, $MAIL_GONE, $ino_cls); if ($^O eq 'linux' && eval { require Linux::Inotify2; 1 }) { $MAIL_IN = Linux::Inotify2::IN_MOVED_TO() | Linux::Inotify2::IN_CREATE(); - $MAIL_GONE = Linux::Inotify2::IN_DELETE(); + $MAIL_GONE = Linux::Inotify2::IN_DELETE() | + Linux::Inotify2::IN_DELETE_SELF() | + Linux::Inotify2::IN_MOVE_SELF(); $ino_cls = 'Linux::Inotify2'; # Perl 5.22+ is needed for fileno(DIRHANDLE) support: } elsif ($^V ge v5.22 && eval { require PublicInbox::KQNotify }) { $MAIL_IN = PublicInbox::KQNotify::MOVED_TO_OR_CREATE(); - $MAIL_GONE = PublicInbox::KQNotify::NOTE_DELETE(); + $MAIL_GONE = PublicInbox::KQNotify::NOTE_DELETE() | + PublicInbox::KQNotify::NOTE_REVOKE() | + PublicInbox::KQNotify::NOTE_RENAME(); $ino_cls = 'PublicInbox::KQNotify'; } else { require PublicInbox::FakeInotify; $MAIL_IN = PublicInbox::FakeInotify::MOVED_TO_OR_CREATE(); - $MAIL_GONE = PublicInbox::FakeInotify::IN_DELETE(); + $MAIL_GONE = PublicInbox::FakeInotify::IN_DELETE() | + PublicInbox::FakeInotify::IN_DELETE_SELF() | + PublicInbox::FakeInotify::IN_MOVE_SELF(); } sub new { |