]> git.ipfire.org Git - thirdparty/public-inbox.git/commitdiff
tail_notify: explicitly detect self deletion
authorEric Wong <e@80x24.org>
Fri, 8 Sep 2023 07:51:29 +0000 (07:51 +0000)
committerEric Wong <e@80x24.org>
Fri, 8 Sep 2023 10:38:40 +0000 (10:38 +0000)
This allows t/tail_notify.t to pass more reliably using
FreeBSD with IO::KQueue.

lib/PublicInbox/TailNotify.pm

index f4ffb29643e6f66c138d90cb480783f88f9e5ab2..bdb92d5402eae8c66a1c601a076f06f52291f41b 100644 (file)
@@ -14,12 +14,14 @@ if ($^O eq 'linux' && eval { require PublicInbox::Inotify; 1 }) {
                Linux::Inotify2::IN_MODIFY();
        $ino_cls = 'PublicInbox::Inotify';
 } elsif (eval { require PublicInbox::KQNotify }) {
-       $TAIL_MOD = PublicInbox::KQNotify::MOVED_TO_OR_CREATE();
+       $TAIL_MOD = PublicInbox::KQNotify::MOVED_TO_OR_CREATE() |
+               IO::KQueue::NOTE_DELETE() | IO::KQueue::NOTE_RENAME();
        $ino_cls = 'PublicInbox::KQNotify';
 } else {
        require PublicInbox::FakeInotify;
        $TAIL_MOD = PublicInbox::FakeInotify::MOVED_TO_OR_CREATE() |
-               PublicInbox::FakeInotify::IN_MODIFY();
+               PublicInbox::FakeInotify::IN_MODIFY() |
+               PublicInbox::FakeInotify::IN_DELETE();
 }
 require IO::Poll if $ino_cls;
 
@@ -49,6 +51,11 @@ sub new {
        $self;
 }
 
+sub delete_self {
+       for (@_) { return 1 if $_->IN_DELETE_SELF }
+       undef;
+}
+
 sub getlines {
        my ($self, $timeo) = @_;
        my ($fh, $buf, $rfds, @ret, @events);
@@ -70,13 +77,12 @@ again:
                }
                select($rfds, undef, undef, $wait);
        }
-       # XXX do we care about @events contents?
-       # use Data::Dumper; warn '# ',Dumper(\@events);
        if ($fh = $self->{watch_fh}) {
                sysread($fh, $buf, -s $fh) and
                        push @ret, split(/^/sm, $buf);
                my @st = stat($self->{fn});
-               if (!@st || "@st[0, 1]" ne $self->{ino_dev}) {
+               if (!@st || "@st[0, 1]" ne $self->{ino_dev} ||
+                               delete_self(@events)) {
                        delete @$self{qw(ino_dev watch_fh)};
                }
        }