about summary refs log tree commit homepage
path: root/lib/PublicInbox/ExtSearchIdx.pm
diff options
context:
space:
mode:
authorEric Wong <e@80x24.org>2021-09-22 02:24:30 +0000
committerEric Wong <e@80x24.org>2021-09-22 05:21:19 +0000
commit28d5a8d647e3ab56cc5570af0d6f3ccf75dc91f2 (patch)
treeabc69aaba694c69febf53ef1965763464035e6bf /lib/PublicInbox/ExtSearchIdx.pm
parent30cc504b0e88302588ca26e91b8005ec62d5d6f2 (diff)
downloadpublic-inbox-28d5a8d647e3ab56cc5570af0d6f3ccf75dc91f2.tar.gz
This fixes the occasional t/lei-sigpipe.t infinite loop
under "make check-run".

Link: http://nntp.perl.org/group/perl.perl5.porters/258784
  <CAHhgV8hPbcmkzWizp6Vijw921M5BOXixj4+zTh3nRS9vRBYk8w@mail.gmail.com>
Followup-to: b552bb9150775fe4 ("daemon+watch: fix localization of %SIG for non-signalfd users")
Diffstat (limited to 'lib/PublicInbox/ExtSearchIdx.pm')
-rw-r--r--lib/PublicInbox/ExtSearchIdx.pm4
1 files changed, 2 insertions, 2 deletions
diff --git a/lib/PublicInbox/ExtSearchIdx.pm b/lib/PublicInbox/ExtSearchIdx.pm
index e0ba6c32..6b29789a 100644
--- a/lib/PublicInbox/ExtSearchIdx.pm
+++ b/lib/PublicInbox/ExtSearchIdx.pm
@@ -1272,7 +1272,7 @@ sub event_step { # PublicInbox::DS::requeue callback
 
 sub eidx_watch { # public-inbox-extindex --watch main loop
         my ($self, $opt) = @_;
-        local %SIG = %SIG;
+        local @SIG{keys %SIG} = values %SIG;
         for my $sig (qw(HUP USR1 TSTP QUIT INT TERM)) {
                 $SIG{$sig} = sub { warn "SIG$sig ignored while scanning\n" };
         }
@@ -1307,7 +1307,7 @@ sub eidx_watch { # public-inbox-extindex --watch main loop
         $sig->{QUIT} = $sig->{INT} = $sig->{TERM} = $quit;
         my $sigfd = PublicInbox::Sigfd->new($sig,
                                         $PublicInbox::Syscall::SFD_NONBLOCK);
-        %SIG = (%SIG, %$sig) if !$sigfd;
+        @SIG{keys %$sig} = values(%$sig) if !$sigfd;
         local $self->{-watch_sync} = $sync; # for ->on_inbox_unlock
         if (!$sigfd) {
                 # wake up every second to accept signals if we don't