]> git.eshelyaron.com Git - emacs.git/commitdiff
(redisplay): When displaying a terminal frame,
authorRichard M. Stallman <rms@gnu.org>
Thu, 3 Aug 1995 23:19:05 +0000 (23:19 +0000)
committerRichard M. Stallman <rms@gnu.org>
Thu, 3 Aug 1995 23:19:05 +0000 (23:19 +0000)
if it isn't the same one as last time, clear it and redraw.
Don't redisplay mini_frame as well, if it is a termcap frame.

src/xdisp.c

index 6a426f80b5cc55378449f44e09bf0b11ae81ebdc..6a4b5dc34ac8d3a8a5ece8339d95372e74db61b9 100644 (file)
@@ -779,6 +779,9 @@ static int do_verify_charstarts;
    no more than once ever 1000 redisplays.  */
 static int clear_face_cache_count;
 
+/* Record the previous terminal frame we displayed.  */
+static FRAME_PTR previous_terminal_frame;
+
 void
 redisplay ()
 {
@@ -792,6 +795,19 @@ redisplay ()
   if (noninteractive)
     return;
 
+#ifdef MULTI_FRAME
+  if (FRAME_TERMCAP_P (selected_frame)
+      && previous_terminal_frame != selected_frame)
+    {
+      /* Since frames on an ASCII terminal share the same display area,
+        displaying a different frame means redisplay the whole thing.  */
+      windows_or_buffers_changed++;
+      SET_FRAME_GARBAGED (selected_frame);
+      XSETFRAME (Vterminal_frame, selected_frame);
+    }
+  previous_terminal_frame = selected_frame;
+#endif
+
   /* Set the visible flags for all frames.
      Do this before checking for resized or garbaged frames; they want
      to know if their frames are visible.
@@ -1094,7 +1110,8 @@ update:
        FRAME_PTR mini_frame
          = XFRAME (WINDOW_FRAME (XWINDOW (minibuf_window)));
        
-       if (mini_frame != selected_frame)
+       if (mini_frame != selected_frame
+           && ! FRAME_TERMCAP_P (mini_frame))
          pause |= update_frame (mini_frame, 0, 0);
       }
     }