diff options
| author | Jim Blandy <jimb@redhat.com> | 1993-02-01 22:31:17 +0000 | 
|---|---|---|
| committer | Jim Blandy <jimb@redhat.com> | 1993-02-01 22:31:17 +0000 | 
| commit | 2aa7a8bfe569d2e0fe9bc7c36378cc9abcf6575d (patch) | |
| tree | bf735595d3f240c476d9ba3d64c12cf5fcdad470 | |
| parent | cbbc8d275ad58fc7a63ce94b7ef6bcd688359a00 (diff) | |
| download | emacs-2aa7a8bfe569d2e0fe9bc7c36378cc9abcf6575d.tar.gz | |
* simple.el (kill-region): If the buffer is read-only, do beep,
	but also put the region in the kill ring.  Doc fix.
| -rw-r--r-- | lisp/simple.el | 20 | 
1 files changed, 15 insertions, 5 deletions
| diff --git a/lisp/simple.el b/lisp/simple.el index 2a47c9d54cd..695f1196730 100644 --- a/lisp/simple.el +++ b/lisp/simple.el @@ -969,6 +969,9 @@ yanking point; just return the Nth kill forward."  The text is deleted but saved in the kill ring.  The command \\[yank] can retrieve it from there.  \(If you want to kill and then yank immediately, use \\[copy-region-as-kill].) +If the buffer is read-only, Emacs will beep and refrain from deleting +the text, but put the text in the kill ring anyway.  This means that +you can use the killing commands to copy text from a read-only buffer.  This is the primitive for programs to kill text (as opposed to deleting it).  Supply two arguments, character numbers indicating the stretch of text @@ -977,12 +980,18 @@ Any command that calls this function is a \"kill command\".  If the previous command was also a kill command,  the text killed this time appends to the text killed last time  to make one entry in the kill ring." -  (interactive "*r") +  (interactive "r")    (cond -   ;; If the buffer was read-only, we used to just do a -   ;; copy-region-as-kill.  This was never what I wanted - usually I -   ;; was making a mistake and trying to edit a file checked into RCS - -   ;; so I've taken the code out. + +   ;; If the buffer is read-only, we should beep, in case the person +   ;; just isn't aware of this.  However, there's no harm in putting +   ;; the region's text in the kill ring, anyway. +   (buffer-read-only +    (copy-region-as-kill beg end) +    (ding)) + +   ;; In certain cases, we can arrange for the undo list and the kill +   ;; ring to share the same string object.  This code does that.     ((not (or (eq buffer-undo-list t)  	     (eq last-command 'kill-region)  	     (eq beg end))) @@ -993,6 +1002,7 @@ to make one entry in the kill ring."        ;; and put it in the kill-ring.        (kill-new (car (car buffer-undo-list)))        (setq this-command 'kill-region))) +     (t      (copy-region-as-kill beg end)      (delete-region beg end)))) | 
