]> git.eshelyaron.com Git - emacs.git/commitdiff
(x_create_tip_frame): Set frame's fringes_extra to 0.
authorJason Rumney <jasonr@gnu.org>
Sun, 25 Nov 2001 11:03:33 +0000 (11:03 +0000)
committerJason Rumney <jasonr@gnu.org>
Sun, 25 Nov 2001 11:03:33 +0000 (11:03 +0000)
(Fx_show_tip): Block input during frame creation.
(Fx_show_tip, Fx_hide_tip): Enable.

src/w32fns.c

index 0dedd61483d851c2ba4274ea2d33c3d6379d48f9..74602bb77658fd17b83231886864f8aa6a518590 100644 (file)
@@ -13243,6 +13243,9 @@ x_create_tip_frame (dpyinfo, parms, text)
   f->output_data.w32->parent_desc = FRAME_W32_DISPLAY_INFO (f)->root_window;
   window_prompting = x_figure_window_size (f, parms);
 
+  /* No fringes on tip frame.  */
+  f->output_data.w32->fringes_extra = 0;
+
   if (window_prompting & XNegative)
     {
       if (window_prompting & YNegative)
@@ -13378,7 +13381,6 @@ compute_tip_xy (f, parms, dx, dy, width, height, root_x, root_y)
 }
 
 
-#ifdef TEST_TOOLTIPS /* Tooltip support in progress.  */
 DEFUN ("x-show-tip", Fx_show_tip, Sx_show_tip, 1, 6, 0,
        doc: /* Show STRING in a \"tooltip\" window on frame FRAME.
 A tooltip window is a small window displaying a string.
@@ -13489,6 +13491,10 @@ Text larger than the specified size is clipped.  */)
     parms = Fcons (Fcons (Qbackground_color, build_string ("lightyellow")),
                   parms);
 
+  /* Block input until the tip has been fully drawn, to avoid crashes
+     when drawing tips in menus.  */
+  BLOCK_INPUT;
+
   /* Create a frame for the tooltip, and record it in the global
      variable tip_frame.  */
   frame = x_create_tip_frame (FRAME_W32_DISPLAY_INFO (f), parms, string);
@@ -13565,7 +13571,6 @@ Text larger than the specified size is clipped.  */)
      show it.  */
   compute_tip_xy (f, parms, dx, dy, width, height, &root_x, &root_y);
 
-  BLOCK_INPUT;
   {
     /* Adjust Window size to take border into account.  */
     RECT rect;
@@ -13584,12 +13589,13 @@ Text larger than the specified size is clipped.  */)
 
     ShowWindow (FRAME_W32_WINDOW (f), SW_SHOWNOACTIVATE);
   }
-  UNBLOCK_INPUT;
 
   /* Draw into the window.  */
   w->must_be_updated_p = 1;
   update_single_window (w, 1);
 
+  UNBLOCK_INPUT;
+
   /* Restore original current buffer.  */
   set_buffer_internal_1 (old_buffer);
   windows_or_buffers_changed = old_windows_or_buffers_changed;
@@ -13638,7 +13644,6 @@ Value is t if tooltip was open, nil otherwise.  */)
   UNGCPRO;
   return unbind_to (count, deleted);
 }
-#endif
 
 
 \f
@@ -14191,6 +14196,11 @@ If the underlying system call fails, value is nil.  */)
   return value;
 }
 \f
+/***********************************************************************
+                           Initialization
+ ***********************************************************************/
+
+void
 syms_of_w32fns ()
 {
   /* This is zero if not using MS-Windows.  */
@@ -14750,10 +14760,8 @@ versions of Windows) characters.  */);
 
   hourglass_atimer = NULL;
   hourglass_shown_p = 0;
-#if TEST_TOOLTIPS /* Tooltip support in progress.  */
   defsubr (&Sx_show_tip);
   defsubr (&Sx_hide_tip);
-#endif
   tip_timer = Qnil;
   staticpro (&tip_timer);
   tip_frame = Qnil;