changeset 39240:e2d428b5bfea

(comint-send-input): When waiting for echoed input, don't save the expected end position in `echo-end', so that things work properly even if the buffer is modified elsewhere at the same time [this happens if `comint-truncate-buffer' is used].
author Miles Bader <miles@gnu.org>
date Tue, 11 Sep 2001 08:40:08 +0000 (2001-09-11)
parents 246f0728f1d7
children 2743aa3f704e
files lisp/comint.el
diffstat 1 files changed, 25 insertions(+), 20 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/comint.el	Tue Sep 11 08:31:16 2001 +0000
+++ b/lisp/comint.el	Tue Sep 11 08:40:08 2001 +0000
@@ -1469,26 +1469,31 @@
 	  (funcall comint-input-sender proc input)
 
 	  ;; Optionally delete echoed input (after checking it).
- 	  (if comint-process-echoes
-	      (let* ((echo-len (- comint-last-input-end
-				  comint-last-input-start))
-		     (echo-end (+ comint-last-input-end echo-len)))
-		;; Wait for all input to be echoed:
-		(while (and (accept-process-output proc)
-			    (> echo-end (point-max))
-			    (= 0 (compare-buffer-substrings
-				  nil comint-last-input-start
-				  (- (point-max) echo-len)
-				  ;; Above difference is equivalent to
-				  ;; (+ comint-last-input-start
-				  ;;    (- (point-max) comint-last-input-end))
-				  nil comint-last-input-end (point-max)))))
- 		(if (and
- 		     (<= echo-end (point-max))
- 		     (= 0 (compare-buffer-substrings
- 			   nil comint-last-input-start comint-last-input-end
- 			   nil comint-last-input-end echo-end)))
- 		    (delete-region comint-last-input-end echo-end))))
+ 	  (when comint-process-echoes
+	    (let ((echo-len (- comint-last-input-end
+			       comint-last-input-start)))
+	      ;; Wait for all input to be echoed:
+	      (while (and (accept-process-output proc)
+			  (> (+ comint-last-input-end echo-len)
+			     (point-max))
+			  (zerop
+			   (compare-buffer-substrings
+			    nil comint-last-input-start
+			    (- (point-max) echo-len)
+			    ;; Above difference is equivalent to
+			    ;; (+ comint-last-input-start
+			    ;;    (- (point-max) comint-last-input-end))
+			    nil comint-last-input-end (point-max)))))
+	      (if (and
+		   (<= (+ comint-last-input-end echo-len)
+		       (point-max))
+		   (zerop
+		    (compare-buffer-substrings
+		     nil comint-last-input-start comint-last-input-end
+		     nil comint-last-input-end
+		     (+ comint-last-input-end echo-len))))
+		  (delete-region comint-last-input-end
+				 (+ comint-last-input-end echo-len)))))
 
 	  ;; This used to call comint-output-filter-functions,
 	  ;; but that scrolled the buffer in undesirable ways.