summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPo Lu <luangruo@yahoo.com>2022-07-28 13:24:10 +0000
committerPo Lu <luangruo@yahoo.com>2022-07-28 13:25:06 +0000
commit977aed9f7981fee0ba9ac8711a86da908fc5057e (patch)
tree10d8239c4efb5b249a676d344f0ec101ea423a39
parentb8fdef7aa65f5b1d2eeb726ff1627d9e169c2b3a (diff)
downloademacs-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.cc25
-rw-r--r--src/haiku_support.h1
-rw-r--r--src/haikumenu.c5
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;