]> git.eshelyaron.com Git - emacs.git/commitdiff
Prevent SelectionNotify etc from reaching GTK 3
authorPo Lu <luangruo@yahoo.com>
Fri, 12 Aug 2022 01:25:12 +0000 (09:25 +0800)
committerPo Lu <luangruo@yahoo.com>
Fri, 12 Aug 2022 01:25:12 +0000 (09:25 +0800)
* src/xterm.c (handle_one_xevent): Prevent selection events from
reaching GTK if they are destined for an Emacs window.

src/xterm.c

index 4372fdb959d669a74f646052b55404464899cf93..48f10269dfc0442bdaa620b59e8e627a7c759571 100644 (file)
@@ -17877,6 +17877,12 @@ handle_one_xevent (struct x_display_info *dpyinfo,
       if (!x_window_to_frame (dpyinfo, event->xselection.requestor))
         goto OTHER;
 #endif /* not USE_X_TOOLKIT and not USE_GTK */
+#ifdef HAVE_GTK3
+      /* GTK 3 apparently chokes on these events since they have no
+        associated device.  (bug#56869, another bug as well that I
+        can't find) */
+      *finish = X_EVENT_DROP;
+#endif
       x_handle_selection_notify (&event->xselection);
       break;
 
@@ -17885,6 +17891,9 @@ handle_one_xevent (struct x_display_info *dpyinfo,
       if (!x_window_to_frame (dpyinfo, event->xselectionclear.window))
         goto OTHER;
 #endif /* not USE_X_TOOLKIT and not USE_GTK */
+#ifdef HAVE_GTK3
+      *finish = X_EVENT_DROP;
+#endif
       {
         const XSelectionClearEvent *eventp = &event->xselectionclear;
 
@@ -17911,6 +17920,9 @@ handle_one_xevent (struct x_display_info *dpyinfo,
       if (!x_window_to_frame (dpyinfo, event->xselectionrequest.owner))
         goto OTHER;
 #endif /* USE_X_TOOLKIT */
+#ifdef HAVE_GTK3
+      *finish = X_EVENT_DROP;
+#endif
       {
        const XSelectionRequestEvent *eventp = &event->xselectionrequest;