speller: block the resizing signal again during an external spell check

Somehow a SIGWINCH pushes nano past the wait() in do_alt_speller(),
even though the external spelling program hasn't finished.

This fixes https://savannah.gnu.org/bugs/?56010
by reverting commit 1f39f60b.

Bug existed since version 3.2.
master
Benno Schulenberg 2019-03-27 17:15:31 +01:00
parent f6a7983a8a
commit 978c121de1
3 changed files with 22 additions and 0 deletions

View File

@ -1362,6 +1362,17 @@ void regenerate_screen(void)
total_refresh(); total_refresh();
} }
/* If allow is FALSE, block any SIGWINCH signal. If allow is TRUE,
* unblock SIGWINCH so any pending ones can be dealt with. */
void allow_sigwinch(bool allow)
{
sigset_t winch;
sigemptyset(&winch);
sigaddset(&winch, SIGWINCH);
sigprocmask(allow ? SIG_UNBLOCK : SIG_BLOCK, &winch, NULL);
}
/* Handle the global toggle specified in flag. */ /* Handle the global toggle specified in flag. */
void do_toggle(int flag) void do_toggle(int flag)
{ {

View File

@ -427,6 +427,7 @@ RETSIGTYPE do_continue(int signal);
#ifndef NANO_TINY #ifndef NANO_TINY
RETSIGTYPE handle_sigwinch(int signal); RETSIGTYPE handle_sigwinch(int signal);
void regenerate_screen(void); void regenerate_screen(void);
void allow_sigwinch(bool allow);
void do_toggle(int flag); void do_toggle(int flag);
void enable_signals(void); void enable_signals(void);
#endif #endif

View File

@ -2652,6 +2652,11 @@ const char *do_alt_speller(char *tempfile_name)
} else if (pid_spell < 0) } else if (pid_spell < 0)
return _("Could not fork"); return _("Could not fork");
#ifndef NANO_TINY
/* Block SIGWINCHes so the spell checker doesn't get any. */
allow_sigwinch(FALSE);
#endif
/* Wait for the alternate spell checker to finish. */ /* Wait for the alternate spell checker to finish. */
wait(&alt_spell_status); wait(&alt_spell_status);
@ -2706,6 +2711,11 @@ const char *do_alt_speller(char *tempfile_name)
adjust_viewport(STATIONARY); adjust_viewport(STATIONARY);
} }
#ifndef NANO_TINY
/* Unblock SIGWINCHes again. */
allow_sigwinch(TRUE);
#endif
return NULL; return NULL;
} }