* 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 external index
https://git.savannah.gnu.org/cgit/emacs.git
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.