]> git.eshelyaron.com Git - emacs.git/commitdiff
* gtkutil.c (xg_frame_set_char_size): Set frame pixel width/height to
authorJan Djärv <jan.h.d@swipnet.se>
Mon, 11 May 2009 06:42:45 +0000 (06:42 +0000)
committerJan Djärv <jan.h.d@swipnet.se>
Mon, 11 May 2009 06:42:45 +0000 (06:42 +0000)
what we expect to get in the next ConfigureNotify event.

src/ChangeLog
src/gtkutil.c

index 0d9c4dd196b5b6e56656060ce705b8a3aa056fc8..4e774d027f0c96c6bdf95de460062ed39b09ac45 100644 (file)
@@ -1,3 +1,8 @@
+2009-05-11  YAMAMOTO Mitsuharu  <mituharu@math.s.chiba-u.ac.jp>
+
+       * 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  <david.reitter@gmail.com>
 
        * nsfns.m (Fx_display_planes): Compute bitplanes using
index 41f2518af8381520dccccd65e6f0dddc0380286a..3ea7c14629a6ad8313911428df30468d347d0428 100644 (file)
@@ -736,6 +736,29 @@ xg_frame_set_char_size (f, cols, rows)
   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);
 }