1
0
mirror of https://git.savannah.gnu.org/git/emacs.git synced 2025-01-27 19:31:38 +00:00

(comint-prompt-read-only): New variable.

(comint-output-filter): Implement it.
This commit is contained in:
Luc Teirlinck 2004-04-29 03:41:48 +00:00
parent d70d59e9d7
commit 70ac607ee3

View File

@ -171,6 +171,14 @@ Good choices:
This is a good thing to set in mode hooks.") This is a good thing to set in mode hooks.")
(defcustom comint-prompt-read-only nil
"If non-nil, the comint prompt is read only.
This does not affect existing prompts.
Certain derived modes may override this option."
:type 'boolean
:group 'comint
:version "21.4")
(defvar comint-delimiter-argument-list () (defvar comint-delimiter-argument-list ()
"List of characters to recognise as separate arguments in input. "List of characters to recognise as separate arguments in input.
Strings comprising a character in this list will separate the arguments Strings comprising a character in this list will separate the arguments
@ -1692,11 +1700,20 @@ Make backspaces delete the previous character."
;; Highlight the prompt, where we define `prompt' to mean ;; Highlight the prompt, where we define `prompt' to mean
;; the most recent output that doesn't end with a newline. ;; the most recent output that doesn't end with a newline.
(let ((prompt-start (save-excursion (forward-line 0) (point)))
(inhibit-read-only t))
(when comint-prompt-read-only
(or (= (point-min) prompt-start)
(get-text-property (1- prompt-start) 'read-only)
(put-text-property
(1- prompt-start) prompt-start 'read-only 'fence))
(add-text-properties
prompt-start (point)
'(read-only t rear-non-sticky t front-sticky (read-only))))
(unless (and (bolp) (null comint-last-prompt-overlay)) (unless (and (bolp) (null comint-last-prompt-overlay))
;; Need to create or move the prompt overlay (in the case ;; Need to create or move the prompt overlay (in the case
;; where there is no prompt ((bolp) == t), we still do ;; where there is no prompt ((bolp) == t), we still do
;; this if there's already an existing overlay). ;; this if there's already an existing overlay).
(let ((prompt-start (save-excursion (forward-line 0) (point))))
(if comint-last-prompt-overlay (if comint-last-prompt-overlay
;; Just move an existing overlay ;; Just move an existing overlay
(move-overlay comint-last-prompt-overlay (move-overlay comint-last-prompt-overlay