# HG changeset patch # User Jan Dj¸«£rv # Date 1242024165 0 # Node ID f63bce93c7a1c2041cd54044511cdbe0bb0fdb0a # Parent 0c6730c52151e6231b41bf45b96b60e6a87c3b94 * gtkutil.c (xg_frame_set_char_size): Set frame pixel width/height to what we expect to get in the next ConfigureNotify event. diff -r 0c6730c52151 -r f63bce93c7a1 src/ChangeLog --- a/src/ChangeLog Mon May 11 06:15:14 2009 +0000 +++ b/src/ChangeLog Mon May 11 06:42:45 2009 +0000 @@ -1,3 +1,8 @@ +2009-05-11 YAMAMOTO Mitsuharu + + * gtkutil.c (xg_frame_set_char_size): Set frame pixel width/height to + what we expect to get in the next ConfigureNotify event. + 2009-05-07 David Reitter * nsfns.m (Fx_display_planes): Compute bitplanes using diff -r 0c6730c52151 -r f63bce93c7a1 src/gtkutil.c --- a/src/gtkutil.c Mon May 11 06:15:14 2009 +0000 +++ b/src/gtkutil.c Mon May 11 06:42:45 2009 +0000 @@ -736,6 +736,29 @@ x_wm_size_hint_off (f); gtk_window_resize (GTK_WINDOW (FRAME_GTK_OUTER_WIDGET (f)), pixelwidth, pixelheight); + + /* Now, strictly speaking, we can't be sure that this is accurate, + but the window manager will get around to dealing with the size + change request eventually, and we'll hear how it went when the + ConfigureNotify event gets here. + + We could just not bother storing any of this information here, + and let the ConfigureNotify event set everything up, but that + might be kind of confusing to the Lisp code, since size changes + wouldn't be reported in the frame parameters until some random + point in the future when the ConfigureNotify event arrives. + + We pass 1 for DELAY since we can't run Lisp code inside of + a BLOCK_INPUT. */ + change_frame_size (f, rows, cols, 0, 1, 0); + FRAME_PIXEL_WIDTH (f) = pixelwidth; + FRAME_PIXEL_HEIGHT (f) = pixelheight; + + /* We've set {FRAME,PIXEL}_{WIDTH,HEIGHT} to the values we hope to + receive in the ConfigureNotify event; if we get what we asked + for, then the event won't cause the screen to become garbaged, so + we have to make sure to do it here. */ + SET_FRAME_GARBAGED (f); flush_and_sync (f); x_wm_set_size_hint (f, 0, 0); }