From: Eric Wong Date: Tue, 28 Mar 2023 02:59:04 +0000 (+0000) Subject: cindex: leave SIGTSTP and SIGCONT unblocked X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=c421c638a77a785903cc829b49131fae3e15a25c;p=thirdparty%2Fpublic-inbox.git cindex: leave SIGTSTP and SIGCONT unblocked This makes it easier to pause and restart long-running indexing jobs which use our event loop. --- diff --git a/lib/PublicInbox/CodeSearchIdx.pm b/lib/PublicInbox/CodeSearchIdx.pm index 6907570d6..9e70087e1 100644 --- a/lib/PublicInbox/CodeSearchIdx.pm +++ b/lib/PublicInbox/CodeSearchIdx.pm @@ -751,7 +751,8 @@ sub cidx_run { # main entry point my ($self) = @_; my $restore_umask = prep_umask($self); local $DEFER = []; - local $SIGSET = PublicInbox::DS::block_signals(); + local $SIGSET = PublicInbox::DS::block_signals( + POSIX::SIGTSTP, POSIX::SIGCONT); my $restore = PublicInbox::OnDestroy->new($$, \&PublicInbox::DS::sig_setmask, $SIGSET); local $LIVE = {}; diff --git a/lib/PublicInbox/DS.pm b/lib/PublicInbox/DS.pm index 340086fc8..98084b5c8 100644 --- a/lib/PublicInbox/DS.pm +++ b/lib/PublicInbox/DS.pm @@ -193,10 +193,11 @@ sub RunTimers { sub sig_setmask { sigprocmask(SIG_SETMASK, @_) or die "sigprocmask: $!" } -sub block_signals () { - my $oldset = POSIX::SigSet->new; +sub block_signals { # anything in @_ stays unblocked my $newset = POSIX::SigSet->new; $newset->fillset or die "fillset: $!"; + $newset->delset($_) for @_; + my $oldset = POSIX::SigSet->new; sig_setmask($newset, $oldset); $oldset; }