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

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).