From: Jan Djärv Date: Mon, 27 Dec 2004 15:23:22 +0000 (+0000) Subject: * Activate.c (XMenuActivate): Return XM_NO_SELECT if Escape or C-g X-Git-Tag: ttn-vms-21-2-B4~3148 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=e89f4e4bd8bb43ecd709695deeb1957a5b39fcb6;p=emacs.git * Activate.c (XMenuActivate): Return XM_NO_SELECT if Escape or C-g was pressed. --- diff --git a/oldXMenu/Activate.c b/oldXMenu/Activate.c index 363b225a355..2f81299cbb6 100644 --- a/oldXMenu/Activate.c +++ b/oldXMenu/Activate.c @@ -81,6 +81,7 @@ #include #include "XMenuInt.h" +#include /* For debug, set this to 0 to not grab the keyboard on menu popup */ int x_menu_grab_keyboard = 1; @@ -131,6 +132,7 @@ XMenuActivate(display, menu, p_num, s_num, x_pos, y_pos, event_mask, data, Window root, child; int root_x, root_y, win_x, win_y; unsigned int mask; + KeySym keysym; /* * Define and allocate a foreign event queue to hold events @@ -458,6 +460,18 @@ XMenuActivate(display, menu, p_num, s_num, x_pos, y_pos, event_mask, data, } selection = True; break; + case KeyPress: + case KeyRelease: + keysym = XLookupKeysym (&event.xkey, 0); + + /* Pop down on C-g and Escape. */ + if ((keysym == XK_g && (event.xkey.state & ControlMask) != 0) + || keysym == XK_Escape) /* Any escape, ignore modifiers. */ + { + ret_val = XM_NO_SELECT; + selection = True; + } + break; default: /* * If AEQ mode is enabled then queue the event. diff --git a/oldXMenu/ChangeLog b/oldXMenu/ChangeLog index ab86c364736..31a786cc23a 100644 --- a/oldXMenu/ChangeLog +++ b/oldXMenu/ChangeLog @@ -1,3 +1,8 @@ +2004-12-27 Jan Dj,Ad(Brv + + * Activate.c (XMenuActivate): Return XM_NO_SELECT if Escape or C-g + was pressed. + 2004-11-12 Jan Dj,Ad(Brv * XMenu.h (XMenuActivateSetWaitFunction): New function.