From: Eli Zaretskii Date: Fri, 17 Jan 2014 11:55:00 +0000 (+0200) Subject: Provisional fix for bug #16479 with client connecting while in a TTY menu. X-Git-Tag: emacs-24.3.90~173^2^2~42^2~45^2~353 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=20adfbd8eaf2427526b582b60db74e0b408e0874;p=emacs.git Provisional fix for bug #16479 with client connecting while in a TTY menu. src/menu.c (Fx_popup_menu): When invoking tty_menu_show, temporarily switch to single keyboard. Prevents daemon crashes when a new client connects while we show a TTY menu in an existing client. --- diff --git a/src/ChangeLog b/src/ChangeLog index 6998df7b625..d36e60a4e95 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,10 @@ +2014-01-17 Eli Zaretskii + + * menu.c (Fx_popup_menu): When invoking tty_menu_show, temporarily + switch to single keyboard. Prevents daemon crashes when a new + client connects while we show a TTY menu in an existing client. + (Bug#16479) + 2014-01-14 Paul Eggert Fix MinGW64 porting problem with _setjmp. diff --git a/src/menu.c b/src/menu.c index dc3198faf0e..c38152f47e8 100644 --- a/src/menu.c +++ b/src/menu.c @@ -1443,8 +1443,16 @@ no quit occurs and `x-popup-menu' returns nil. */) else #endif if (FRAME_TERMCAP_P (f)) - selection = tty_menu_show (f, xpos, ypos, for_click, keymaps, title, - kbd_menu_navigation, &error_name); + { + ptrdiff_t count1 = SPECPDL_INDEX (); + + /* Avoid crashes if, e.g., another client will connect while we + are in a menu. */ + temporarily_switch_to_single_kboard (f); + selection = tty_menu_show (f, xpos, ypos, for_click, keymaps, title, + kbd_menu_navigation, &error_name); + unbind_to (count1, Qnil); + } #ifdef HAVE_NS unbind_to (specpdl_count, Qnil);