unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#43844: 27.1; Mouse-3 avoid "Buffer is read-only" *patch*
@ 2020-10-07 11:34 Corwin Brust
  2020-10-07 15:14 ` Noam Postavsky
  0 siblings, 1 reply; 7+ messages in thread
From: Corwin Brust @ 2020-10-07 11:34 UTC (permalink / raw)
  To: 43844


[-- Attachment #1.1: Type: text/plain, Size: 3703 bytes --]

In Dired, ERC, and, I assume, any read-only buffer the default behavior of
mouse-3 causes errors (E.g. "kill-region: Buffer is read-only: #<buffer
*Messages*>").

The attached patch attempts to prevent this by detecting a
read-only-buffer.  Unfortunately, it seems that ERC has some other means
of causing its buffers to be rendered read-only that doesn't affect
this var, thus the special-case logic.  I tested with dired, erc, and
(regression tested) while composing this bug report.

Are there other edge cases like erc-mode hanging around, where
read-only-buffer might not be accurate?  Is this oddity with ERC worth a
separate bug report?  Finally, s there a more elegant way to special
case whatever erc-mode is doing?

This is my first attempt at submitting a patch.  I will dig a bit more
into my own questions, above; tia for tips, suggestions, etc.

In GNU Emacs 27.1 (build 1, x86_64-w64-mingw32)
 of 2020-08-21 built on CIRROCUMULUS
Repository revision: 86d8d76aa36037184db0b2897c434cdaab1a9ae8
Repository branch: HEAD
Windowing system distributor 'Microsoft Corp.', version 10.0.18363
System Description: Microsoft Windows 10 Home (v10.0.1909.18363.1082)

Recent messages:
For information about GNU Emacs and the GNU system, type C-h C-a.

Configured using:
 'configure --without-dbus --host=x86_64-w64-mingw32
 --without-compress-install 'CFLAGS=-O2 -static''

Configured features:
XPM JPEG TIFF GIF PNG RSVG SOUND NOTIFY W32NOTIFY ACL GNUTLS LIBXML2
HARFBUZZ ZLIB TOOLKIT_SCROLL_BARS MODULES THREADS JSON PDUMPER LCMS2 GMP

Important settings:
  value of $LANG: ENU
  locale-coding-system: cp1252

Major mode: Lisp Interaction

Minor modes in effect:
  tooltip-mode: t
  global-eldoc-mode: t
  eldoc-mode: t
  electric-indent-mode: t
  mouse-wheel-mode: t
  tool-bar-mode: t
  menu-bar-mode: t
  file-name-shadow-mode: t
  global-font-lock-mode: t
  font-lock-mode: t
  blink-cursor-mode: t
  auto-composition-mode: t
  auto-encryption-mode: t
  auto-compression-mode: t
  line-number-mode: t
  transient-mark-mode: t

Load-path shadows:
None found.

Features:
(shadow sort mail-extr emacsbug message rmc puny dired dired-loaddefs
format-spec rfc822 mml easymenu mml-sec password-cache epa derived epg
epg-config gnus-util rmail rmail-loaddefs text-property-search time-date
subr-x seq byte-opt gv bytecomp byte-compile cconv mm-decode mm-bodies
mm-encode mail-parse rfc2231 mailabbrev gmm-utils mailheader cl-loaddefs
cl-lib sendmail rfc2047 rfc2045 ietf-drums mm-util mail-prsvr mail-utils
tooltip eldoc electric uniquify ediff-hook vc-hooks lisp-float-type
mwheel dos-w32 ls-lisp disp-table term/w32-win w32-win w32-vars
term/common-win tool-bar dnd fontset image regexp-opt fringe
tabulated-list replace newcomment text-mode elisp-mode lisp-mode
prog-mode register page tab-bar menu-bar rfn-eshadow isearch timer
select scroll-bar mouse jit-lock font-lock syntax facemenu font-core
term/tty-colors frame minibuffer cl-generic cham georgian utf-8-lang
misc-lang vietnamese tibetan thai tai-viet lao korean japanese eucjp-ms
cp51932 hebrew greek romanian slovak czech european ethiopic indian
cyrillic chinese composite charscript charprop case-table epa-hook
jka-cmpr-hook help simple abbrev obarray cl-preloaded nadvice loaddefs
button faces cus-face macroexp files text-properties overlay sha1 md5
base64 format env code-pages mule custom widget hashtable-print-readable
backquote threads w32notify w32 lcms2 multi-tty make-network-process
emacs)

Memory information:
((conses 16 46659 8583)
 (symbols 48 6075 1)
 (strings 32 16982 2021)
 (string-bytes 1 519943)
 (vectors 16 9274)
 (vector-slots 8 123598 13156)
 (floats 8 22 312)
 (intervals 56 222 0)
 (buffers 1000 12))


Corwin

[-- Attachment #1.2: Type: text/html, Size: 4097 bytes --]

[-- Attachment #2: mouse-3_no-kill-when-readonly-or-erc-mode.patch --]
[-- Type: application/octet-stream, Size: 1350 bytes --]

diff -u "c:/emacs/share/emacs/27.1/lisp/mouse.el-27.1" "c:/emacs/share/emacs/27.1/lisp/mouse.el"
--- c:/emacs/share/emacs/27.1/lisp/mouse.el-27.1	2020-10-07 05:13:58.000000000 -0500
+++ c:/emacs/share/emacs/27.1/lisp/mouse.el	2020-10-07 05:28:12.511318900 -0500
@@ -1601,8 +1601,10 @@
 previous region was just saved to the kill ring).
 
 If this command is called a second consecutive time with the same
-CLICK position, kill the region (or delete it
-if `mouse-drag-copy-region' is non-nil)."
+CLICK position, kill the region (or delete it if
+`mouse-drag-copy-region' is non-nil).  When buffer is
+read-only (or an `erc-mode' derived mode), use `kill-ring-save'
+instead of `kill-region'."
   (interactive "e")
   (mouse-minibuffer-check click)
   (let* ((posn     (event-start click))
@@ -1628,7 +1630,9 @@
           ;; Region already saved in the previous click;
           ;; don't make a duplicate entry, just delete.
           (funcall region-extract-function 'delete-only)
-        (kill-region (mark t) (point) 'region))
+        (if (or buffer-read-only (derived-mode-p 'erc-mode))
+	    (kill-ring-save (mark t) (point) 'region)
+	  (kill-region (mark t) (point) 'region)))
       (setq mouse-selection-click-count 0)
       (setq mouse-save-then-kill-posn nil))
 

Diff finished.  Wed Oct  7 05:31:50 2020

^ permalink raw reply	[flat|nested] 7+ messages in thread

* bug#43844: 27.1; Mouse-3 avoid "Buffer is read-only" *patch*
  2020-10-07 11:34 bug#43844: 27.1; Mouse-3 avoid "Buffer is read-only" *patch* Corwin Brust
@ 2020-10-07 15:14 ` Noam Postavsky
  2021-01-27  5:37   ` Lars Ingebrigtsen
  0 siblings, 1 reply; 7+ messages in thread
From: Noam Postavsky @ 2020-10-07 15:14 UTC (permalink / raw)
  To: Corwin Brust; +Cc: 43844

Corwin Brust <corwin@bru.st> writes:

> In Dired, ERC, and, I assume, any read-only buffer the default behavior of
> mouse-3 causes errors (E.g. "kill-region: Buffer is read-only: #<buffer
> *Messages*>").

I think you just need to set the kill-read-only-ok option.

    kill-read-only-ok is a variable defined in ‘simple.el’.
    Its value is nil

    Documentation:
    Non-nil means don’t signal an error for killing read-only text.

> Unfortunately, it seems that ERC has some other means of causing its
> buffers to be rendered read-only that doesn't affect this var, thus
> the special-case logic.

I'm guessing ERC marks only some of text as read-only via text
properties.





^ permalink raw reply	[flat|nested] 7+ messages in thread

* bug#43844: 27.1; Mouse-3 avoid "Buffer is read-only" *patch*
  2020-10-07 15:14 ` Noam Postavsky
@ 2021-01-27  5:37   ` Lars Ingebrigtsen
  2021-01-28 20:20     ` Corwin Brust
  0 siblings, 1 reply; 7+ messages in thread
From: Lars Ingebrigtsen @ 2021-01-27  5:37 UTC (permalink / raw)
  To: Noam Postavsky; +Cc: 43844, Corwin Brust

Noam Postavsky <npostavs@gmail.com> writes:

> I think you just need to set the kill-read-only-ok option.
>
>     kill-read-only-ok is a variable defined in ‘simple.el’.
>     Its value is nil
>
>     Documentation:
>     Non-nil means don’t signal an error for killing read-only text.

So I think this works as designed, and I'm closing this bug report.

-- 
(domestic pets only, the antidote for overdose, milk.)
   bloggy blog: http://lars.ingebrigtsen.no





^ permalink raw reply	[flat|nested] 7+ messages in thread

* bug#43844: 27.1; Mouse-3 avoid "Buffer is read-only" *patch*
  2021-01-27  5:37   ` Lars Ingebrigtsen
@ 2021-01-28 20:20     ` Corwin Brust
  2021-01-29  5:02       ` Lars Ingebrigtsen
  0 siblings, 1 reply; 7+ messages in thread
From: Corwin Brust @ 2021-01-28 20:20 UTC (permalink / raw)
  To: Lars Ingebrigtsen; +Cc: 43844, Noam Postavsky

[-- Attachment #1: Type: text/plain, Size: 940 bytes --]

Hi Lars,

Apologies for not having followed-up on this and thank you for lending it
your attention.

On Tue, Jan 26, 2021 at 11:37 PM Lars Ingebrigtsen <larsi@gnus.org> wrote:

> Noam Postavsky <npostavs@gmail.com> writes:
>
> > I think you just need to set the kill-read-only-ok option.
> >
> >     kill-read-only-ok is a variable defined in ‘simple.el’.
> >     Its value is nil
> >
> >     Documentation:
> >     Non-nil means don’t signal an error for killing read-only text.
>
> So I think this works as designed, and I'm closing this bug report.
>

I disagree this behavior makes sense.

Should it be the users responsibility to set this variable (in some hook?
which?) for any buffers that default to read-only?

Again, thanks!


>
> --
> (domestic pets only, the antidote for overdose, milk.)
>    bloggy blog: http://lars.ingebrigtsen.no
>


-- 
*Corwin*
*corwin@bru.st <corwin@bru.st>*

[-- Attachment #2: Type: text/html, Size: 2038 bytes --]

^ permalink raw reply	[flat|nested] 7+ messages in thread

* bug#43844: 27.1; Mouse-3 avoid "Buffer is read-only" *patch*
  2021-01-28 20:20     ` Corwin Brust
@ 2021-01-29  5:02       ` Lars Ingebrigtsen
  2021-01-29 15:10         ` Corwin Brust
  0 siblings, 1 reply; 7+ messages in thread
From: Lars Ingebrigtsen @ 2021-01-29  5:02 UTC (permalink / raw)
  To: Corwin Brust; +Cc: 43844, Noam Postavsky

Corwin Brust <corwin@bru.st> writes:

> Should it be the users responsibility to set this variable (in some
> hook? which?) for any buffers that default to read-only?

Yes.  Some buffers have read-only text, and killing that text will
signal an error (by design), whether you kill the text using the mouse
or with `C-w'.  If the user wants to be able to kill the text, then the
user should set that variable.

-- 
(domestic pets only, the antidote for overdose, milk.)
   bloggy blog: http://lars.ingebrigtsen.no





^ permalink raw reply	[flat|nested] 7+ messages in thread

* bug#43844: 27.1; Mouse-3 avoid "Buffer is read-only" *patch*
  2021-01-29  5:02       ` Lars Ingebrigtsen
@ 2021-01-29 15:10         ` Corwin Brust
  2021-01-30  6:14           ` Lars Ingebrigtsen
  0 siblings, 1 reply; 7+ messages in thread
From: Corwin Brust @ 2021-01-29 15:10 UTC (permalink / raw)
  To: Lars Ingebrigtsen; +Cc: 43844, Noam Postavsky

Thanks again Lars.

On Thu, Jan 28, 2021 at 11:02 PM Lars Ingebrigtsen <larsi@gnus.org> wrote:
>
> Corwin Brust <corwin@bru.st> writes:
>
> > Should it be the users responsibility to set this variable (in some
> > hook? which?) for any buffers that default to read-only?
>
> Yes.  Some buffers have read-only text, and killing that text will
> signal an error (by design), whether you kill the text using the mouse
> or with `C-w'.  If the user wants to be able to kill the text, then the
> user should set that variable.

Would you recommend packages such as ERC (or dired?) that essentially
create only read-only buffers to set this such that unconfigured
defaults don't lead to a user-error?

>
> --
> (domestic pets only, the antidote for overdose, milk.)
>    bloggy blog: http://lars.ingebrigtsen.no


Regards,
Corwin





^ permalink raw reply	[flat|nested] 7+ messages in thread

* bug#43844: 27.1; Mouse-3 avoid "Buffer is read-only" *patch*
  2021-01-29 15:10         ` Corwin Brust
@ 2021-01-30  6:14           ` Lars Ingebrigtsen
  0 siblings, 0 replies; 7+ messages in thread
From: Lars Ingebrigtsen @ 2021-01-30  6:14 UTC (permalink / raw)
  To: Corwin Brust; +Cc: 43844, Noam Postavsky

Corwin Brust <corwin@bru.st> writes:

> Would you recommend packages such as ERC (or dired?) that essentially
> create only read-only buffers to set this such that unconfigured
> defaults don't lead to a user-error?

I'm not sure what you mean here?  Buffers that make text read-only do so
because the person who wrote that mode thinks that's a good design
decision.  As usual, Emacs allows users to override anything if they
want to, and `kill-read-only-ok' is the provided user override.

-- 
(domestic pets only, the antidote for overdose, milk.)
   bloggy blog: http://lars.ingebrigtsen.no





^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2021-01-30  6:14 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2020-10-07 11:34 bug#43844: 27.1; Mouse-3 avoid "Buffer is read-only" *patch* Corwin Brust
2020-10-07 15:14 ` Noam Postavsky
2021-01-27  5:37   ` Lars Ingebrigtsen
2021-01-28 20:20     ` Corwin Brust
2021-01-29  5:02       ` Lars Ingebrigtsen
2021-01-29 15:10         ` Corwin Brust
2021-01-30  6:14           ` Lars Ingebrigtsen

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).