unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#42356: 28.0.50; [patch] cperl-mode: (cperl-write-tags) fails
@ 2020-07-14 15:22 Harald Jörg
  2020-08-05 13:39 ` Lars Ingebrigtsen
  0 siblings, 1 reply; 2+ messages in thread
From: Harald Jörg @ 2020-07-14 15:22 UTC (permalink / raw)
  To: 42356

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

How to reproduce:

1) Open a file with arbitrary Perl code, for example like that:
   ----
   package Tag::It;

   sub bark {
       say 'woof!';
   }
   ----
2) M-x cperl-mode
3) From the menu, Perl->Tools->Tags->Create tags for current file
   (or any other entry which creates tags from the same submenu)

This fails with "cond: Buffer is read-only: #<buffer TAGS>".

I *guess* this is related to recent changes in etags.pl which need to be
accomodated for in cperl-mode.  The function works fine in Emacs 26.1
(as available in Debian Buster.

Attached is a one-line fix, but I am unsure whether this is the right
way to deal with it.

Note 1: As a workaround one could of course use cperl-etags
        (which is an interactive function), but this is also
        broken, albeit in a different way.  Already reported
        as (bug#42355).

Note 2: No need to remind me of copyright paperwork:  I've sent
        the form to assign@gnu.org on July 02, and pinged them
        again on July 13.

In GNU Emacs 28.0.50 (build 1, x86_64-pc-linux-gnu, X toolkit, Xaw
scroll bars)
 of 2020-07-07 built on hajtower
Repository revision: 6b80ff3c465f87a31ccaaf41b2b521075f43632d
Repository branch: master
Windowing system distributor 'The X.Org Foundation', version 11.0.12004000
System Description: Debian GNU/Linux 10 (buster)

Recent messages:
Quit [2 times]
Making completion list... [2 times]
Auto-saving...done
<left-fringe> <mouse-1> is undefined [2 times]
Mark set [2 times]
Auto-saving...
Beginning of buffer [4 times]
user-error: Beginning of history; no preceding item
user-error: End of history; no default available [3 times]
completing-read-default: Command attempted to use minibuffer while in
minibuffer

Configured features:
XPM JPEG TIFF GIF PNG SOUND NOTIFY INOTIFY GNUTLS LIBXML2 ZLIB
TOOLKIT_SCROLL_BARS LUCID X11 XDBE XIM MODULES THREADS PDUMPER GMP

Important settings:
  value of $LANG: en_US.UTF-8
  locale-coding-system: utf-8-unix

Major mode: Help

Minor modes in effect:
  tooltip-mode: t
  global-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
  buffer-read-only: t
  line-number-mode: t
  transient-mark-mode: t

Load-path shadows:
None found.

Features:
(pp shadow sort mail-extr emacsbug message rmc puny dired dired-loaddefs
rfc822 mml mml-sec password-cache epa epg epg-config gnus-util rmail
rmail-loaddefs text-property-search mm-decode mm-bodies mm-encode
mail-parse rfc2231 mailabbrev gmm-utils mailheader sendmail rfc2047
rfc2045 ietf-drums mm-util mail-prsvr mail-utils apropos mule-util
misearch multi-isearch bug-reference cl-extra seq cl-print cus-edit
wid-edit cus-start cus-load thingatpt help-fns radix-tree help-mode
perl-mode time-date subr-x vc-git diff-mode easy-mmode cperl-mode
derived info man ansi-color etags fileloop generator xref cl-seq project
eieio byte-opt bytecomp byte-compile cconv eieio-core cl-macs gv
eieio-loaddefs ring easymenu imenu cl-loaddefs cl-lib tooltip eldoc
electric uniquify ediff-hook vc-hooks lisp-float-type mwheel term/x-win
x-win term/common-win x-dnd 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 inotify dynamic-setting x-toolkit x multi-tty
make-network-process emacs)

Memory information:
((conses 16 133165 14283)
 (symbols 48 10626 1)
 (strings 32 36309 2069)
 (string-bytes 1 1030321)
 (vectors 16 17217)
 (vector-slots 8 293029 19492)
 (floats 8 56 44)
 (intervals 56 1604 21)
 (buffers 992 21))

[-- Attachment #2: 0001-cperl-mode-Workaround-for-failure-of-cperl-write-tag.patch --]
[-- Type: text/x-patch, Size: 712 bytes --]

From 5d04d7a123e53c5c9e141a2b94e6a9b532bbe4d2 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Harald=20J=C3=B6rg?= <haj@posteo.de>
Date: Tue, 14 Jul 2020 16:40:04 +0200
Subject: [PATCH] cperl-mode: Workaround for failure of cperl-write-tags

---
 lisp/progmodes/cperl-mode.el | 1 +
 1 file changed, 1 insertion(+)

diff --git a/lisp/progmodes/cperl-mode.el b/lisp/progmodes/cperl-mode.el
index cdbb59a5ad..6755d10f1a 100644
--- a/lisp/progmodes/cperl-mode.el
+++ b/lisp/progmodes/cperl-mode.el
@@ -6786,6 +6786,7 @@ cperl-write-tags
   (or topdir
       (setq topdir default-directory))
   (let ((tags-file-name "TAGS")
+        (inhibit-read-only t)
 	(case-fold-search nil)
 	xs rel)
     (save-excursion
-- 
2.20.1


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

* bug#42356: 28.0.50; [patch] cperl-mode: (cperl-write-tags) fails
  2020-07-14 15:22 bug#42356: 28.0.50; [patch] cperl-mode: (cperl-write-tags) fails Harald Jörg
@ 2020-08-05 13:39 ` Lars Ingebrigtsen
  0 siblings, 0 replies; 2+ messages in thread
From: Lars Ingebrigtsen @ 2020-08-05 13:39 UTC (permalink / raw)
  To: Harald Jörg; +Cc: 42356

Harald Jörg <haj@posteo.de> writes:

> This fails with "cond: Buffer is read-only: #<buffer TAGS>".
>
> I *guess* this is related to recent changes in etags.pl which need to be
> accomodated for in cperl-mode.  The function works fine in Emacs 26.1
> (as available in Debian Buster.
>
> Attached is a one-line fix, but I am unsure whether this is the right
> way to deal with it.

I'm not very familiar with the code here, but it makes sense to me.
Applied to Emacs 28.

> Note 2: No need to remind me of copyright paperwork:  I've sent
>         the form to assign@gnu.org on July 02, and pinged them
>         again on July 13.

And according to the copyright.list file, the paperwork has gone
through.

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





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

end of thread, other threads:[~2020-08-05 13:39 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-07-14 15:22 bug#42356: 28.0.50; [patch] cperl-mode: (cperl-write-tags) fails Harald Jörg
2020-08-05 13:39 ` 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).