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:
parent
d70d59e9d7
commit
70ac607ee3
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user