about summary refs log tree commit homepage
path: root/lib/PublicInbox/IPC.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/IPC.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/IPC.pm')
-rw-r--r--lib/PublicInbox/IPC.pm4
1 files changed, 2 insertions, 2 deletions
diff --git a/lib/PublicInbox/IPC.pm b/lib/PublicInbox/IPC.pm
index 1c699d76..3e29def8 100644
--- a/lib/PublicInbox/IPC.pm
+++ b/lib/PublicInbox/IPC.pm
@@ -115,7 +115,7 @@ sub ipc_worker_spawn {
                         $fields //= {};
                         local @$self{keys %$fields} = values(%$fields);
                         my $on_destroy = $self->ipc_atfork_child;
-                        local %SIG = %SIG;
+                        local @SIG{keys %SIG} = values %SIG;
                         PublicInbox::DS::sig_setmask($sigset);
                         ipc_worker_loop($self, $r_req, $w_res);
                 };
@@ -361,7 +361,7 @@ sub _wq_worker_start ($$$$) {
                         $fields //= {};
                         local @$self{keys %$fields} = values(%$fields);
                         my $on_destroy = $self->ipc_atfork_child;
-                        local %SIG = %SIG;
+                        local @SIG{keys %SIG} = values %SIG;
                         PublicInbox::DS::sig_setmask($oldset);
                         wq_worker_loop($self, $bcast2);
                 };