From: Gerd Moellmann Date: Fri, 7 Sep 2001 13:30:50 +0000 (+0000) Subject: (comint-send-input): Handle comint-process-echoes X-Git-Tag: emacs-pretest-21.0.106~200 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=c9e74cd4be9caeb8c1b3d43f4f5b708184e9aa06;p=emacs.git (comint-send-input): Handle comint-process-echoes differently. --- diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 249e46e06e8..239dd228879 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,10 +1,15 @@ +2001-09-07 Dr Francis J. Wright + + * comint.el (comint-send-input): Handle comint-process-echoes + differently. + 2001-09-07 Eli Zaretskii * arc-mode.el (archive-dostime): Fix a typo in minutes' computation. 2001-09-07 Gerd Moellmann - + * server.el (server-switch-buffer): Use get-window-with-predicate. * textmodes/refer.el (refer-find-entry-internal): Use diff --git a/lisp/comint.el b/lisp/comint.el index e93a9f956e7..24ffe55ed71 100644 --- a/lisp/comint.el +++ b/lisp/comint.el @@ -1422,9 +1422,7 @@ Similarly for Soar, Scheme, etc." (delete-region pmark start) copy)))) - (if comint-process-echoes - (delete-region pmark (point)) - (insert ?\n)) + (insert ?\n) (comint-add-to-input-history history) @@ -1469,6 +1467,29 @@ Similarly for Soar, Scheme, etc." ;; clear the "accumulation" marker (set-marker comint-accum-marker nil) (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)))) + ;; This used to call comint-output-filter-functions, ;; but that scrolled the buffer in undesirable ways. (run-hook-with-args 'comint-output-filter-functions ""))))) @@ -1540,7 +1561,7 @@ This function should be in the list `comint-output-filter-functions'." (delete-char -2))))))))) (add-hook 'comint-output-filter-functions 'comint-carriage-motion) - + ;; The purpose of using this filter for comint processes ;; is to keep comint-last-input-end from moving forward ;; when output is inserted.