diff options
author | Po Lu <luangruo@yahoo.com> | 2022-07-28 13:24:10 +0000 |
---|---|---|
committer | Po Lu <luangruo@yahoo.com> | 2022-07-28 13:25:06 +0000 |
commit | 977aed9f7981fee0ba9ac8711a86da908fc5057e (patch) | |
tree | 10d8239c4efb5b249a676d344f0ec101ea423a39 | |
parent | b8fdef7aa65f5b1d2eeb726ff1627d9e169c2b3a (diff) | |
download | emacs-977aed9f7981fee0ba9ac8711a86da908fc5057e.tar.gz emacs-977aed9f7981fee0ba9ac8711a86da908fc5057e.tar.bz2 emacs-977aed9f7981fee0ba9ac8711a86da908fc5057e.zip |
Fix grab view persisting on Haiku after popup menu closes
* src/haiku_support.cc (BasicMouseUp): Improve handling of
wait_for_release_message.
(be_clear_grab_view): New function.
* src/haiku_support.h: Update prototypes.
* src/haikumenu.c (haiku_menu_show): Call it here.
-rw-r--r-- | src/haiku_support.cc | 25 | ||||
-rw-r--r-- | src/haiku_support.h | 1 | ||||
-rw-r--r-- | src/haikumenu.c | 5 |
3 files changed, 27 insertions, 4 deletions
diff --git a/src/haiku_support.cc b/src/haiku_support.cc index cb378d2d810..b7590f68a48 100644 --- a/src/haiku_support.cc +++ b/src/haiku_support.cc @@ -1930,11 +1930,14 @@ public: button = (grabbed_buttons & ~buttons); grabbed_buttons = buttons; - if (!grabbed_buttons && wait_for_release_message) + if (wait_for_release_message) { - wait_for_release_message->SendReply (wait_for_release_message); - delete wait_for_release_message; - wait_for_release_message = NULL; + if (!grabbed_buttons) + { + wait_for_release_message->SendReply (wait_for_release_message); + delete wait_for_release_message; + wait_for_release_message = NULL; + } return; } @@ -5457,3 +5460,17 @@ be_get_explicit_workarea (int *x, int *y, int *width, int *height) return true; } + +/* Clear the grab view. This has to be called manually from some + places, since we don't get B_MOUSE_UP messages after a popup menu + is run. */ + +void +be_clear_grab_view (void) +{ + if (grab_view_locker.Lock ()) + { + grab_view = NULL; + grab_view_locker.Unlock (); + } +} diff --git a/src/haiku_support.h b/src/haiku_support.h index 5577d2f151f..76fe071f2c9 100644 --- a/src/haiku_support.h +++ b/src/haiku_support.h @@ -727,6 +727,7 @@ extern void be_set_window_fullscreen_mode (void *, enum haiku_fullscreen_mode); extern void be_lock_window (void *); extern void be_unlock_window (void *); extern bool be_get_explicit_workarea (int *, int *, int *, int *); +extern void be_clear_grab_view (void); #ifdef __cplusplus } diff --git a/src/haikumenu.c b/src/haikumenu.c index 929ed952105..69bb56c124e 100644 --- a/src/haikumenu.c +++ b/src/haikumenu.c @@ -432,6 +432,11 @@ haiku_menu_show (struct frame *f, int x, int y, int menuflags, FRAME_DISPLAY_INFO (f)->grabbed = 0; + /* Clear the grab view manually. There is a race condition here if + the window thread receives a button press between here and the + end of BMenu_run. */ + be_clear_grab_view (); + if (menu_item_selection) { prefix = entry = Qnil; |