]> git.eshelyaron.com Git - emacs.git/commitdiff
(x_window_to_menu_bar) [USE_LUCID]: New function.
authorGerd Moellmann <gerd@gnu.org>
Mon, 30 Apr 2001 14:38:34 +0000 (14:38 +0000)
committerGerd Moellmann <gerd@gnu.org>
Mon, 30 Apr 2001 14:38:34 +0000 (14:38 +0000)
(XTread_socket) [USE_LUCID] <Expose>: Handle events for
windows that are components of a Lucid menu bar.

src/ChangeLog
src/xterm.c

index f0ae3d17eacc29a8b23d0a868c3e78d4048c68d0..282d0a2de2ce0e74a77c5c395c99d010b92540c3 100644 (file)
@@ -1,3 +1,9 @@
+2001-04-30  Gerd Moellmann  <gerd@gnu.org>
+
+       * xterm.c (x_window_to_menu_bar) [USE_LUCID]: New function.
+       (XTread_socket) <Expose> [USE_LUCID]: Handle events for 
+       windows that are components of a Lucid menu bar.
+
 2001-04-27  Gerd Moellmann  <gerd@gnu.org>
 
        * term.c (turn_on_face): Fix reverse video handling on terminals
index 15ba1e9c6dc322194950cc0b465b279398ceac28..118c1261ee93ad7a890a31f02d8772e7b3f079dd 100644 (file)
@@ -8037,6 +8037,33 @@ x_window_to_scroll_bar (window_id)
 }
 
 
+#if defined USE_X_TOOLKIT && defined USE_LUCID
+
+/* Return the Lucid menu bar WINDOW is part of.  Return null
+   if WINDOW is not part of a menu bar.  */
+
+static Widget
+x_window_to_menu_bar (window)
+     Window window;
+{
+  Lisp_Object tail;
+  
+  for (tail = Vframe_list;
+       XGCTYPE (tail) == Lisp_Cons;
+       tail = XCDR (tail))
+    {
+      Lisp_Object frame = XCAR (tail);
+      Widget menu_bar = XFRAME (frame)->output_data.x->menubar_widget;
+      
+      if (menu_bar && xlwmenu_window_p (menu_bar, window))
+       return menu_bar;
+    }
+
+  return NULL;
+}
+
+#endif /* USE_X_TOOLKIT && USE_LUCID */
+
 \f
 /************************************************************************
                         Toolkit scroll bars
@@ -9990,6 +10017,18 @@ XTread_socket (sd, bufp, numchars, expected)
                }
              else
                {
+#if defined USE_X_TOOLKIT && defined USE_LUCID
+                 /* Submenus of the Lucid menu bar aren't widgets
+                    themselves, so there's no way to dispatch events
+                    to them.  Recognize this case separately.  */
+                 {
+                   Widget widget
+                     = x_window_to_menu_bar (event.xexpose.window);
+                   if (widget)
+                     xlwmenu_redisplay (widget);
+                 }
+#endif /* USE_X_TOOLKIT && USE_LUCID */
+                 
 #ifdef USE_TOOLKIT_SCROLL_BARS
                  /* Dispatch event to the widget.  */
                  goto OTHER;