Daniel Novotny cc45bc
diff -up emacs-23.1/src/gtkutil.c.scroll emacs-23.1/src/gtkutil.c
Daniel Novotny cc45bc
--- emacs-23.1/src/gtkutil.c.scroll	2009-06-21 06:38:15.000000000 +0200
Daniel Novotny cc45bc
+++ emacs-23.1/src/gtkutil.c	2009-12-02 17:10:08.000000000 +0100
Daniel Novotny cc45bc
@@ -3401,6 +3401,38 @@ xg_set_toolkit_scroll_bar_thumb (bar, po
Daniel Novotny cc45bc
     }
Daniel Novotny cc45bc
 }
Daniel Novotny cc45bc
 
Daniel Novotny cc45bc
+/* Return non-zero if EVENT is for a scroll bar in frame F.
Daniel Novotny cc45bc
+   When the same X window is used for several Gtk+ widgets, we cannot
Daniel Novotny cc45bc
+   say for sure based on the X window alone if an event is for the
Daniel Novotny cc45bc
+   frame.  This function does additional checks.
Daniel Novotny cc45bc
+
Daniel Novotny cc45bc
+   Return non-zero if the event is for a scroll bar, zero otherwise.  */
Daniel Novotny cc45bc
+
Daniel Novotny cc45bc
+int
Daniel Novotny cc45bc
+xg_event_is_for_scrollbar (f, event)
Daniel Novotny cc45bc
+     FRAME_PTR f;
Daniel Novotny cc45bc
+     XEvent *event;
Daniel Novotny cc45bc
+{
Daniel Novotny cc45bc
+  int retval = 0;
Daniel Novotny cc45bc
+
Daniel Novotny cc45bc
+  if (f && event->type == ButtonPress)
Daniel Novotny cc45bc
+    {
Daniel Novotny cc45bc
+      /* Check if press occurred outside the edit widget.  */
Daniel Novotny cc45bc
+      GdkDisplay *gdpy = gdk_x11_lookup_xdisplay (FRAME_X_DISPLAY (f));
Daniel Novotny cc45bc
+      retval = gdk_display_get_window_at_pointer (gdpy, NULL, NULL)
Daniel Novotny cc45bc
+        != f->output_data.x->edit_widget->window;
Daniel Novotny cc45bc
+    }
Daniel Novotny cc45bc
+  else if (f && (event->type != ButtonRelease || event->type != MotionNotify))
Daniel Novotny cc45bc
+    {
Daniel Novotny cc45bc
+      /* If we are releasing or moving the scroll bar, it has the grab.  */
Daniel Novotny cc45bc
+      retval = gtk_grab_get_current () != 0
Daniel Novotny cc45bc
+        && gtk_grab_get_current () != f->output_data.x->edit_widget;
Daniel Novotny cc45bc
+    }
Daniel Novotny cc45bc
+
Daniel Novotny cc45bc
+  return retval;
Daniel Novotny cc45bc
+}
Daniel Novotny cc45bc
+
Daniel Novotny cc45bc
+
Daniel Novotny cc45bc
 
Daniel Novotny cc45bc
 /***********************************************************************
Daniel Novotny cc45bc
                       Tool bar functions
Daniel Novotny cc45bc
diff -up emacs-23.1/src/gtkutil.h.scroll emacs-23.1/src/gtkutil.h
Daniel Novotny cc45bc
--- emacs-23.1/src/gtkutil.h.scroll	2009-06-21 06:38:15.000000000 +0200
Daniel Novotny cc45bc
+++ emacs-23.1/src/gtkutil.h	2009-12-02 17:10:08.000000000 +0100
Daniel Novotny cc45bc
@@ -180,6 +180,8 @@ extern void xg_set_toolkit_scroll_bar_th
Daniel Novotny cc45bc
                                                  int position,
Daniel Novotny cc45bc
                                                  int whole));
Daniel Novotny cc45bc
 
Daniel Novotny cc45bc
+extern int xg_event_is_for_scrollbar P_ ((FRAME_PTR f, XEvent *event));
Daniel Novotny cc45bc
+
Daniel Novotny cc45bc
 
Daniel Novotny cc45bc
 extern void update_frame_tool_bar P_ ((FRAME_PTR f));
Daniel Novotny cc45bc
 extern void free_frame_tool_bar P_ ((FRAME_PTR f));
Daniel Novotny cc45bc
diff -up emacs-23.1/src/xterm.c.scroll emacs-23.1/src/xterm.c
Daniel Novotny cc45bc
--- emacs-23.1/src/xterm.c.scroll	2009-06-21 06:38:20.000000000 +0200
Daniel Novotny cc45bc
+++ emacs-23.1/src/xterm.c	2009-12-02 17:13:24.000000000 +0100
Daniel Novotny cc45bc
@@ -6743,6 +6743,12 @@ handle_one_xevent (dpyinfo, eventp, fini
Daniel Novotny cc45bc
             clear_mouse_face (dpyinfo);
Daniel Novotny cc45bc
           }
Daniel Novotny cc45bc
 
Daniel Novotny cc45bc
+
Daniel Novotny cc45bc
+#ifdef USE_GTK
Daniel Novotny cc45bc
+        if (f && xg_event_is_for_scrollbar (f, &event))
Daniel Novotny cc45bc
+          f = 0;
Daniel Novotny cc45bc
+#endif
Daniel Novotny cc45bc
+
Daniel Novotny cc45bc
         if (f)
Daniel Novotny cc45bc
           {
Daniel Novotny cc45bc
 
Daniel Novotny cc45bc
@@ -6899,6 +6905,11 @@ handle_one_xevent (dpyinfo, eventp, fini
Daniel Novotny cc45bc
         else
Daniel Novotny cc45bc
           f = x_window_to_frame (dpyinfo, event.xbutton.window);
Daniel Novotny cc45bc
 
Daniel Novotny cc45bc
+#ifdef USE_GTK
Daniel Novotny cc45bc
+        if (f && xg_event_is_for_scrollbar (f, &event))
Daniel Novotny cc45bc
+          f = 0;
Daniel Novotny cc45bc
+#endif
Daniel Novotny cc45bc
+
Daniel Novotny cc45bc
         if (f)
Daniel Novotny cc45bc
           {
Daniel Novotny cc45bc
             /* Is this in the tool-bar?  */