changeset 101690:1009d5607716

* dispnew.c (window_change_signal): Don't try to get the size of a suspended tty frame. * term.c (Fresume_tty): Resize if the size has changed while the tty was suspended.
author Dan Nicolaescu <dann@ics.uci.edu>
date Fri, 30 Jan 2009 23:45:27 +0000
parents 697627d7beda
children 6066300ce217
files src/ChangeLog src/dispnew.c src/term.c
diffstat 3 files changed, 23 insertions(+), 1 deletions(-) [+]
line wrap: on
line diff
--- a/src/ChangeLog	Fri Jan 30 23:43:20 2009 +0000
+++ b/src/ChangeLog	Fri Jan 30 23:45:27 2009 +0000
@@ -1,5 +1,10 @@
 2009-01-30  Dan Nicolaescu  <dann@ics.uci.edu>
 
+	* dispnew.c (window_change_signal): Don't try to get the size of a
+	suspended tty frame.
+	* term.c (Fresume_tty): Resize if the size has changed while the
+	tty was suspended.
+
 	* alloc.c (mark_stack): Properly conditionalize previous change.
 
 2009-01-30  Juanma Barranquero  <lekktu@gmail.com>
--- a/src/dispnew.c	Fri Jan 30 23:43:20 2009 +0000
+++ b/src/dispnew.c	Fri Jan 30 23:45:27 2009 +0000
@@ -6218,6 +6218,11 @@
     if (! tty->term_initted)
       continue;
 
+    /* Suspended tty frames have tty->input == NULL avoid trying to
+       use it.  */
+    if (!tty->input)
+      continue;
+
     get_tty_size (fileno (tty->input), &width, &height);
 
     if (width > 5 && height > 2) {
--- a/src/term.c	Fri Jan 30 23:43:20 2009 +0000
+++ b/src/term.c	Fri Jan 30 23:45:27 2009 +0000
@@ -2470,7 +2470,19 @@
 #endif
 
       if (FRAMEP (t->display_info.tty->top_frame))
-        FRAME_SET_VISIBLE (XFRAME (t->display_info.tty->top_frame), 1);
+	{
+	  struct frame *f = XFRAME (t->display_info.tty->top_frame);
+	  int width, height;
+	  int old_height = FRAME_COLS (f);
+	  int old_width = FRAME_LINES (f);
+
+	  /* Check if terminal/window size has changed while the frame
+	     was suspended.  */
+	  get_tty_size (fileno (t->display_info.tty->input), &width, &height);
+	  if (width != old_width || height != old_height)
+	    change_frame_size (f, height, width, 0, 0, 0);
+	  FRAME_SET_VISIBLE (XFRAME (t->display_info.tty->top_frame), 1);
+	}
 
       init_sys_modes (t->display_info.tty);