unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#73710: 30.0.91; skeleton-transformation-function sometimes unbound when sgml-xml-mode is t
@ 2024-10-08 18:09 Mike Kupfer
  2024-10-13 12:01 ` Eli Zaretskii
  0 siblings, 1 reply; 4+ messages in thread
From: Mike Kupfer @ 2024-10-08 18:09 UTC (permalink / raw)
  To: 73710

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

sgml-mode.el has an autoload for #'skeleton-read, which will pull in
skeleton.el and define skeleton-transformation-function.  But it looks
like there are code paths that don't trigger the autoload, so you can
get "Symbol’s value as variable is void: skeleton-transformation-function".

Reproducer:

- save the attached test file to disk

- emacs -Q
- M-: (setq sgml-xml-mode t) RET
- visit the test file
- move point to the "t" in "<table>"
- C-c C-a

mike

In GNU Emacs 30.0.91 (build 1, x86_64-pc-linux-gnu, X toolkit, cairo
 version 1.16.0, Xaw scroll bars) of 2024-09-12 built on alto
Windowing system distributor 'The X.Org Foundation', version 11.0.12101007
System Description: Debian GNU/Linux 12 (bookworm)

Configured using:
 'configure --prefix=/usr/local --with-native-compilation=no'

Configured features:
CAIRO FREETYPE GIF GLIB GMP GNUTLS GSETTINGS HARFBUZZ JPEG LIBSELINUX
LIBXML2 MODULES NOTIFY INOTIFY PDUMPER PNG SECCOMP SOUND THREADS TIFF
TOOLKIT_SCROLL_BARS WEBP X11 XDBE XIM XPM LUCID ZLIB

Important settings:
  value of $LC_TIME: C
  value of $LANG: en_US.UTF-8
  value of $XMODIFIERS: @im=ibus
  locale-coding-system: utf-8-unix

Major mode: XHTML+

Minor modes in effect:
  tooltip-mode: t
  global-eldoc-mode: t
  show-paren-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
  minibuffer-regexp-mode: t
  line-number-mode: t
  indent-tabs-mode: t
  transient-mark-mode: t
  auto-composition-mode: t
  auto-encryption-mode: t
  auto-compression-mode: t

Load-path shadows:
None found.

Features:
(shadow sort mail-extr emacsbug message dired dired-loaddefs rfc822 mml
mml-sec epa derived epg rfc6068 epg-config mm-decode mm-bodies mm-encode
mail-parse rfc2231 mailabbrev gmm-utils mailheader sendmail rfc2047
rfc2045 ietf-drums yank-media mhtml-mode css-mode smie eww xdg url-queue
thingatpt shr pixel-fill kinsoku url-file svg xml browse-url url
url-proxy url-privacy url-expand url-methods url-history url-cookie
generate-lisp-file url-domsuf url-util url-parse auth-source cl-seq
eieio eieio-core cl-macs icons password-cache url-vars mailcap puny
mm-url gnus nnheader gnus-util text-property-search time-date mail-utils
range wid-edit mm-util mail-prsvr color js c-ts-common treesit json
subr-x map byte-opt gv bytecomp byte-compile imenu cc-mode cc-fonts
cc-guess cc-menus cc-cmds cc-styles cc-align cc-engine cc-vars cc-defs
sgml-mode facemenu dom cl-loaddefs cl-lib rmc iso-transl tooltip cconv
eldoc paren electric uniquify ediff-hook vc-hooks lisp-float-type
elisp-mode mwheel term/x-win x-win term/common-win x-dnd touch-screen
tool-bar dnd fontset image regexp-opt fringe tabulated-list replace
newcomment text-mode lisp-mode prog-mode register page tab-bar menu-bar
rfn-eshadow isearch easymenu timer select scroll-bar mouse jit-lock
font-lock syntax font-core term/tty-colors frame minibuffer nadvice seq
simple cl-generic indonesian philippine 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 emoji-zwj charscript charprop case-table
epa-hook jka-cmpr-hook help abbrev obarray oclosure cl-preloaded button
loaddefs theme-loaddefs faces cus-face macroexp files window
text-properties overlay sha1 md5 base64 format env code-pages mule
custom widget keymap hashtable-print-readable backquote threads inotify
dynamic-setting system-font-setting font-render-setting cairo x-toolkit
x multi-tty move-toolbar make-network-process emacs)

Memory information:
((conses 16 116311 9450) (symbols 48 12713 0) (strings 32 37306 2002)
 (string-bytes 1 1070017) (vectors 16 20833)
 (vector-slots 8 213859 10039) (floats 8 188 1) (intervals 56 300 0)
 (buffers 984 12))


[-- Attachment #2: test file --]
[-- Type: text/html, Size: 92 bytes --]

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

* bug#73710: 30.0.91; skeleton-transformation-function sometimes unbound when sgml-xml-mode is t
  2024-10-08 18:09 bug#73710: 30.0.91; skeleton-transformation-function sometimes unbound when sgml-xml-mode is t Mike Kupfer
@ 2024-10-13 12:01 ` Eli Zaretskii
  2024-10-19  1:09   ` Mike Kupfer
  0 siblings, 1 reply; 4+ messages in thread
From: Eli Zaretskii @ 2024-10-13 12:01 UTC (permalink / raw)
  To: Mike Kupfer; +Cc: 73710

> From: Mike Kupfer <kupfer@rawbw.com>
> Date: Tue, 08 Oct 2024 11:09:27 -0700
> 
> sgml-mode.el has an autoload for #'skeleton-read, which will pull in
> skeleton.el and define skeleton-transformation-function.  But it looks
> like there are code paths that don't trigger the autoload, so you can
> get "Symbol’s value as variable is void: skeleton-transformation-function".
> 
> Reproducer:
> 
> - save the attached test file to disk
> 
> - emacs -Q
> - M-: (setq sgml-xml-mode t) RET
> - visit the test file
> - move point to the "t" in "<table>"
> - C-c C-a

Thanks.

Does the patch below give good results?

diff --git a/lisp/textmodes/sgml-mode.el b/lisp/textmodes/sgml-mode.el
index f126df8..ee58589 100644
--- a/lisp/textmodes/sgml-mode.el
+++ b/lisp/textmodes/sgml-mode.el
@@ -533,6 +533,7 @@ sgml-mode-facemenu-add-face-function
   "Add \"face\" tags with `facemenu-keymap' commands."
   (let ((tag-face (ensure-list (cdr (assq face sgml-face-tag-alist)))))
     (cond (tag-face
+           (require 'skeleton)
 	   (setq tag-face (funcall skeleton-transformation-function tag-face))
            (setq facemenu-end-add-face
                  (mapconcat (lambda (f) (concat "</" f ">")) (reverse tag-face)))
@@ -851,6 +852,7 @@ sgml-attributes
             (setq alist (cons '("class") alist)))
           (unless (assoc-string "id" alist)
             (setq alist (cons '("id") alist))))
+        (require 'skeleton)
 	(if (stringp (car alist))
 	    (progn
 	      (insert (if (eq (preceding-char) ?\s) "" ?\s)





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

* bug#73710: 30.0.91; skeleton-transformation-function sometimes unbound when sgml-xml-mode is t
  2024-10-13 12:01 ` Eli Zaretskii
@ 2024-10-19  1:09   ` Mike Kupfer
  2024-10-19  6:42     ` Eli Zaretskii
  0 siblings, 1 reply; 4+ messages in thread
From: Mike Kupfer @ 2024-10-19  1:09 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: 73710

Eli Zaretskii wrote:

> Does the patch below give good results?

Yes, thanks.  I verified it against my test case and installed it on my
desktop a few days ago; no problems.

mike





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

* bug#73710: 30.0.91; skeleton-transformation-function sometimes unbound when sgml-xml-mode is t
  2024-10-19  1:09   ` Mike Kupfer
@ 2024-10-19  6:42     ` Eli Zaretskii
  0 siblings, 0 replies; 4+ messages in thread
From: Eli Zaretskii @ 2024-10-19  6:42 UTC (permalink / raw)
  To: Mike Kupfer; +Cc: 73710-done

> From: Mike Kupfer <kupfer@rawbw.com>
> cc: 73710@debbugs.gnu.org
> Comments: In-reply-to Eli Zaretskii <eliz@gnu.org>
>    message dated "Sun, 13 Oct 2024 15:01:13 +0300."
> Date: Fri, 18 Oct 2024 18:09:37 -0700
> 
> Eli Zaretskii wrote:
> 
> > Does the patch below give good results?
> 
> Yes, thanks.  I verified it against my test case and installed it on my
> desktop a few days ago; no problems.

Thanks for testing.  I've now installed the fix on the master branch,
and I'm therefore closing this bug.





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

end of thread, other threads:[~2024-10-19  6:42 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-10-08 18:09 bug#73710: 30.0.91; skeleton-transformation-function sometimes unbound when sgml-xml-mode is t Mike Kupfer
2024-10-13 12:01 ` Eli Zaretskii
2024-10-19  1:09   ` Mike Kupfer
2024-10-19  6:42     ` Eli Zaretskii

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