]> Sergey Matveev's repositories - public-inbox.git/blobdiff - script/public-inbox-watch
No ext_urls
[public-inbox.git] / script / public-inbox-watch
index 645abeda971688b3849e77de4bd5cdd46960b0b2..4c50461ff4c02950d14d1aa763e0319bd3ee059f 100755 (executable)
@@ -1,26 +1,58 @@
 #!/usr/bin/perl -w
-# Copyright (C) 2016-2020 all contributors <meta@public-inbox.org>
+# Copyright (C) all contributors <meta@public-inbox.org>
 # License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
+my $help = <<EOF;
+usage: public-inbox-watch
+
+See public-inbox-watch(1) man page for full documentation.
+EOF
+
 use strict;
-use warnings;
-use PublicInbox::WatchMaildir;
+use Getopt::Long qw(:config gnu_getopt no_ignore_case auto_abbrev);
+use IO::Handle; # ->autoflush
+use PublicInbox::Watch;
 use PublicInbox::Config;
-my ($config, $watch_md);
+use PublicInbox::DS;
+my $do_scan = 1;
+GetOptions('scan!' => \$do_scan, # undocumented, testing only
+       'help|h' => \(my $show_help)) or do { print STDERR $help; exit 1 };
+if ($show_help) { print $help; exit 0 };
+my $oldset = PublicInbox::DS::block_signals();
+STDOUT->autoflush(1);
+STDERR->autoflush(1);
+local $0 = $0; # local since this script may be eval-ed
+my $watch = PublicInbox::Watch->new(PublicInbox::Config->new);
 my $reload = sub {
-       $config = PublicInbox::Config->new;
-       $watch_md->quit if $watch_md;
-       $watch_md = PublicInbox::WatchMaildir->new($config);
+       my $prev = $watch or return; # SIGQUIT issued
+       $watch->quit;
+       $watch = PublicInbox::Watch->new(PublicInbox::Config->new);
+       if ($watch) {
+               warn "# reloaded\n";
+       } else {
+               warn("E: reloading failed\n");
+               $watch = $prev;
+       }
 };
-$reload->();
-if ($watch_md) {
-       my $scan = sub { $watch_md->trigger_scan('full') if $watch_md };
-       $SIG{HUP} = $reload;
-       $SIG{USR1} = $scan;
-       $SIG{ALRM} = sub { $SIG{ALRM} = 'DEFAULT'; $scan->() };
-       $SIG{QUIT} = $SIG{TERM} = $SIG{INT} = sub {
-               $watch_md->quit if $watch_md;
-               $watch_md = undef;
+
+if ($watch) {
+       my $scan = sub {
+               return if !$watch;
+               warn "# scanning\n";
+               $watch->trigger_scan('full');
        };
-       alarm(1);
-       $watch_md->watch while ($watch_md);
+       my $quit = sub {
+               $watch->quit if $watch;
+               $watch = undef;
+               $0 .= ' quitting';
+       };
+       my $sig = {
+               HUP => $reload,
+               USR1 => $scan,
+               CHLD => \&PublicInbox::DS::enqueue_reap,
+       };
+       $sig->{QUIT} = $sig->{TERM} = $sig->{INT} = $quit;
+
+       # --no-scan is only intended for testing atm, undocumented.
+       PublicInbox::DS::requeue($scan) if $do_scan;
+       $watch->watch($sig, $oldset) while ($watch);
 }