From 0e3fcdef7f85f7f2efef7415f32f3f8a0ef44d11 Mon Sep 17 00:00:00 2001 From: Jason Rumney Date: Sun, 25 Nov 2001 11:03:33 +0000 Subject: [PATCH] (x_create_tip_frame): Set frame's fringes_extra to 0. (Fx_show_tip): Block input during frame creation. (Fx_show_tip, Fx_hide_tip): Enable. --- src/w32fns.c | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/src/w32fns.c b/src/w32fns.c index 0dedd61483d..74602bb7765 100644 --- a/src/w32fns.c +++ b/src/w32fns.c @@ -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 @@ -14191,6 +14196,11 @@ If the underlying system call fails, value is nil. */) return value; } +/*********************************************************************** + 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; -- 2.39.5