]> Sergey Matveev's repositories - public-inbox.git/blobdiff - script/public-inbox-watch
daemon+watch: fix localization of %SIG for non-signalfd users
[public-inbox.git] / script / public-inbox-watch
index 9ada9c3b22e11756baeb429a63c4619ff1237fe7..86349d71d415ba12314411f25e87b0c227018022 100755 (executable)
@@ -19,7 +19,7 @@ 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::Sigfd::block_signals();
+my $oldset = PublicInbox::DS::block_signals();
 STDOUT->autoflush(1);
 STDERR->autoflush(1);
 local $0 = $0; # local since this script may be eval-ed
@@ -58,9 +58,9 @@ if ($watch) {
        PublicInbox::DS::requeue($scan) if $do_scan;
 
        my $sigfd = PublicInbox::Sigfd->new($sig, SFD_NONBLOCK);
-       local %SIG = (%SIG, %$sig) if !$sigfd;
+       local @SIG{keys %$sig} = values(%$sig) unless $sigfd;
        if (!$sigfd) {
-               PublicInbox::Sigfd::sig_setmask($oldset);
+               PublicInbox::DS::sig_setmask($oldset);
                PublicInbox::DS->SetLoopTimeout(1000);
        }
        $watch->watch($sig, $oldset) while ($watch);