diff options
| author | Po Lu | 2022-10-21 19:19:33 +0800 |
|---|---|---|
| committer | Po Lu | 2022-10-21 19:19:48 +0800 |
| commit | ea70e545c90e0cbfe3ea33c31ba3ef4f3487c32c (patch) | |
| tree | 84597e41e5fecc497010b3ea76525e70d5c0991a /src | |
| parent | 4b40b790ae003032daa612807bc59e17f2c29dca (diff) | |
| download | emacs-ea70e545c90e0cbfe3ea33c31ba3ef4f3487c32c.tar.gz emacs-ea70e545c90e0cbfe3ea33c31ba3ef4f3487c32c.zip | |
Fix delivery of window manager ping events during menu
* oldXMenu/Activate.c (XMenuActivateSetExposeFunction)
(XMenuActivate):
* oldXMenu/XMenu.h: Remove expose functions.
* src/msdos.h (XMenuSetAEQ): Remove no longer used function.
* src/xmenu.c (x_menu_expose_event): Delete function.
(x_menu_dispatch_event): New function.
(x_menu_show): Set it as the XMenu event handler.
Diffstat (limited to 'src')
| -rw-r--r-- | src/msdos.h | 1 | ||||
| -rw-r--r-- | src/xmenu.c | 14 |
2 files changed, 9 insertions, 6 deletions
diff --git a/src/msdos.h b/src/msdos.h index 24697bcf24b..1b304cf02b9 100644 --- a/src/msdos.h +++ b/src/msdos.h | |||
| @@ -123,7 +123,6 @@ extern void x_set_menu_bar_lines (struct frame *, Lisp_Object, Lisp_Object); | |||
| 123 | #define XGetGeometry(p1,p2,p3,p4,p5,p6,p7,p8,p9) | 123 | #define XGetGeometry(p1,p2,p3,p4,p5,p6,p7,p8,p9) |
| 124 | #define DisplayWidth(p1,p2) (SELECTED_FRAME()->text_cols) | 124 | #define DisplayWidth(p1,p2) (SELECTED_FRAME()->text_cols) |
| 125 | #define DisplayHeight(p1,p2) (SELECTED_FRAME()->text_lines) | 125 | #define DisplayHeight(p1,p2) (SELECTED_FRAME()->text_lines) |
| 126 | #define XMenuSetAEQ (void) | ||
| 127 | #define XMenuSetFreeze (void) | 126 | #define XMenuSetFreeze (void) |
| 128 | #define XMenuRecompute (void) | 127 | #define XMenuRecompute (void) |
| 129 | #define XM_FAILURE -1 | 128 | #define XM_FAILURE -1 |
diff --git a/src/xmenu.c b/src/xmenu.c index 9d35e3529fb..d9660a6910f 100644 --- a/src/xmenu.c +++ b/src/xmenu.c | |||
| @@ -294,10 +294,13 @@ x_menu_translate_generic_event (XEvent *event) | |||
| 294 | #endif | 294 | #endif |
| 295 | 295 | ||
| 296 | #if !defined USE_X_TOOLKIT && !defined USE_GTK | 296 | #if !defined USE_X_TOOLKIT && !defined USE_GTK |
| 297 | static void | 297 | static int |
| 298 | x_menu_expose_event (XEvent *event) | 298 | x_menu_dispatch_event (XEvent *event) |
| 299 | { | 299 | { |
| 300 | x_dispatch_event (event, event->xexpose.display); | 300 | x_dispatch_event (event, event->xexpose.display); |
| 301 | |||
| 302 | /* The return doesn't really matter. */ | ||
| 303 | return 0; | ||
| 301 | } | 304 | } |
| 302 | #endif | 305 | #endif |
| 303 | #endif /* ! MSDOS */ | 306 | #endif /* ! MSDOS */ |
| @@ -2747,21 +2750,22 @@ x_menu_show (struct frame *f, int x, int y, int menuflags, | |||
| 2747 | y += 1.5 * height/ (maxlines + 2); | 2750 | y += 1.5 * height/ (maxlines + 2); |
| 2748 | } | 2751 | } |
| 2749 | 2752 | ||
| 2750 | XMenuSetAEQ (menu, true); | ||
| 2751 | XMenuSetFreeze (menu, true); | 2753 | XMenuSetFreeze (menu, true); |
| 2752 | pane = selidx = 0; | 2754 | pane = selidx = 0; |
| 2753 | 2755 | ||
| 2754 | #ifndef MSDOS | 2756 | #ifndef MSDOS |
| 2755 | DEFER_SELECTIONS; | 2757 | DEFER_SELECTIONS; |
| 2756 | 2758 | ||
| 2757 | XMenuActivateSetWaitFunction (x_menu_wait_for_event, FRAME_X_DISPLAY (f)); | 2759 | XMenuActivateSetWaitFunction (x_menu_wait_for_event, |
| 2760 | FRAME_X_DISPLAY (f)); | ||
| 2761 | XMenuEventHandler (x_menu_dispatch_event); | ||
| 2762 | |||
| 2758 | /* When the input extension is in use, the owner_events grab will | 2763 | /* When the input extension is in use, the owner_events grab will |
| 2759 | report extension events on frames, which the XMenu library does | 2764 | report extension events on frames, which the XMenu library does |
| 2760 | not normally understand. */ | 2765 | not normally understand. */ |
| 2761 | #ifdef HAVE_XINPUT2 | 2766 | #ifdef HAVE_XINPUT2 |
| 2762 | XMenuActivateSetTranslateFunction (x_menu_translate_generic_event); | 2767 | XMenuActivateSetTranslateFunction (x_menu_translate_generic_event); |
| 2763 | #endif | 2768 | #endif |
| 2764 | XMenuActivateSetExposeFunction (x_menu_expose_event); | ||
| 2765 | #endif | 2769 | #endif |
| 2766 | 2770 | ||
| 2767 | record_unwind_protect_ptr (pop_down_menu, | 2771 | record_unwind_protect_ptr (pop_down_menu, |