From c421c638a77a785903cc829b49131fae3e15a25c Mon Sep 17 00:00:00 2001 From: Eric Wong Date: Tue, 28 Mar 2023 02:59:04 +0000 Subject: cindex: leave SIGTSTP and SIGCONT unblocked This makes it easier to pause and restart long-running indexing jobs which use our event loop. --- lib/PublicInbox/CodeSearchIdx.pm | 3 ++- lib/PublicInbox/DS.pm | 5 +++-- 2 files changed, 5 insertions(+), 3 deletions(-) (limited to 'lib/PublicInbox') diff --git a/lib/PublicInbox/CodeSearchIdx.pm b/lib/PublicInbox/CodeSearchIdx.pm index 6907570d..9e70087e 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 340086fc..98084b5c 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; } -- cgit v1.2.3-24-ge0c7