GNU bug report logs - #58808
map-y-or-n-p should use read-key, not read-event

Previous Next

Package: emacs;

Reported by: meedstrom <at> teknik.io

Date: Thu, 27 Oct 2022 01:01:02 UTC

Severity: normal

To reply to this bug, email your comments to 58808 AT debbugs.gnu.org.

Toggle the display of automated, internal messages from the tracker.

View this report as an mbox folder, status mbox, maintainer mbox


Report forwarded to bug-gnu-emacs <at> gnu.org:
bug#58808; Package emacs. (Thu, 27 Oct 2022 01:01:02 GMT) Full text and rfc822 format available.

Acknowledgement sent to meedstrom <at> teknik.io:
New bug report received and forwarded. Copy sent to bug-gnu-emacs <at> gnu.org. (Thu, 27 Oct 2022 01:01:02 GMT) Full text and rfc822 format available.

Message #5 received at submit <at> debbugs.gnu.org (full text, mbox):

From: meedstrom <at> teknik.io
To: bug-gnu-emacs <at> gnu.org
Subject: map-y-or-n-p should use read-key, not read-event
Date: Wed, 26 Oct 2022 23:59:46 +0000
[Message part 1 (text/plain, inline)]
I found that map-y-or-n-p uses read-event, not read-key (still the case in master as of 2022-10-27).  Will you accept a patch if I try to rewrite it?

Background: I like to translate <escape> to C-g, so I can hit the physical Esc key.  It almost always works, except in two cases; when Emacs freezes, and when something calls map-y-or-n-p, like the command M-x save-some-buffers.

An additional concern is that while map-y-or-n-p is doing its thing, even the triplet ESC ESC ESC does not work!

Steps to reproduce:

1. Start Emacs -Q
2. Eval (define-key function-key-map (kbd "<escape>") (kbd "C-g"))
3. Edit some new file
4. Type C-x s to trigger save-some-buffers
5. Attempt to cancel by hitting the Escape key

--------

In GNU Emacs 28.2 (build 1, x86_64-pc-linux-gnu, GTK+ Version 3.24.34, cairo version 1.17.6)
 of 2022-09-12 built on frederik
Windowing system distributor 'The X.Org Foundation', version 11.0.12101004
System Description: Arch Linux

Configured using:
 'configure --sysconfdir=/etc --prefix=/usr --libexecdir=/usr/lib
 --localstatedir=/var --with-cairo --with-harfbuzz --with-libsystemd
 --with-modules --with-x-toolkit=gtk3 'CFLAGS=-march=x86-64
 -mtune=generic -O2 -pipe -fno-plt -fexceptions -Wp,-D_FORTIFY_SOURCE=2
 -Wformat -Werror=format-security -fstack-clash-protection
 -fcf-protection -g -ffile-prefix-map=/build/emacs/src=/usr/src/debug
 -flto=auto' 'LDFLAGS=-Wl,-O1,--sort-common,--as-needed,-z,relro,-z,now
 -flto=auto''

Configured features:
ACL CAIRO DBUS FREETYPE GIF GLIB GMP GNUTLS GPM GSETTINGS HARFBUZZ JPEG
JSON LCMS2 LIBOTF LIBSYSTEMD LIBXML2 M17N_FLT MODULES NOTIFY INOTIFY
PDUMPER PNG RSVG SECCOMP SOUND THREADS TIFF TOOLKIT_SCROLL_BARS X11 XDBE
XIM XPM GTK3 ZLIB

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

Major mode: Fundamental

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
  auto-composition-mode: t
  auto-encryption-mode: t
  auto-compression-mode: t
  line-number-mode: t
  indent-tabs-mode: t
  transient-mark-mode: t

Load-path shadows:
None found.

Features:
(shadow sort mail-extr emacsbug message rmc puny dired dired-loaddefs
rfc822 mml mml-sec epa derived epg rfc6068 epg-config gnus-util rmail
rmail-loaddefs auth-source cl-seq eieio eieio-core cl-macs
eieio-loaddefs password-cache json map text-property-search seq byte-opt
gv bytecomp byte-compile cconv mm-decode mm-bodies mm-encode mail-parse
rfc2231 mailabbrev gmm-utils mailheader sendmail rfc2047 rfc2045
ietf-drums mm-util mail-prsvr mail-utils time-date subr-x cl-loaddefs
cl-lib iso-transl tooltip eldoc paren electric uniquify ediff-hook
vc-hooks lisp-float-type elisp-mode 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 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 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 emoji-zwj charscript charprop case-table epa-hook
jka-cmpr-hook help simple abbrev obarray cl-preloaded nadvice button
loaddefs faces cus-face macroexp files window text-properties overlay
sha1 md5 base64 format env code-pages mule custom widget
hashtable-print-readable backquote threads dbusbind inotify lcms2
dynamic-setting system-font-setting font-render-setting cairo
move-toolbar gtk x-toolkit x multi-tty make-network-process emacs)

Memory information:
((conses 16 51060 7072)
 (symbols 48 6633 1)
 (strings 32 18318 1832)
 (string-bytes 1 604358)
 (vectors 16 13634)
 (vector-slots 8 183648 9467)
 (floats 8 22 46)
 (intervals 56 242 0)
 (buffers 992 12))
[Message part 2 (text/html, inline)]

Information forwarded to bug-gnu-emacs <at> gnu.org:
bug#58808; Package emacs. (Thu, 27 Oct 2022 06:00:02 GMT) Full text and rfc822 format available.

Message #8 received at 58808 <at> debbugs.gnu.org (full text, mbox):

From: Eli Zaretskii <eliz <at> gnu.org>
To: meedstrom <at> teknik.io, Stefan Monnier <monnier <at> iro.umontreal.ca>
Cc: 58808 <at> debbugs.gnu.org
Subject: Re: bug#58808: map-y-or-n-p should use read-key, not read-event
Date: Thu, 27 Oct 2022 08:58:53 +0300
> Date: Wed, 26 Oct 2022 23:59:46 +0000
> From: meedstrom--- via "Bug reports for GNU Emacs,
>  the Swiss army knife of text editors" <bug-gnu-emacs <at> gnu.org>
> 
> I found that map-y-or-n-p uses read-event, not read-key (still the case in master as of 2022-10-27).  Will you
> accept a patch if I try to rewrite it?
> 
> Background: I like to translate <escape> to C-g, so I can hit the physical Esc key.  It almost always works,
> except in two cases; when Emacs freezes, and when something calls map-y-or-n-p, like the command M-x
> save-some-buffers.
> 
> An additional concern is that while map-y-or-n-p is doing its thing, even the triplet ESC ESC ESC does not
> work!
> 
> Steps to reproduce:
> 
> 1. Start Emacs -Q
> 2. Eval (define-key function-key-map (kbd "<escape>") (kbd "C-g"))
> 3. Edit some new file
> 4. Type C-x s to trigger save-some-buffers
> 5. Attempt to cancel by hitting the Escape key

Isn't there some translation map that could help you?

Adding Stefan to CC, in case he has comments.

(I'd assume that map-y-or-n-p would work like y-or-n-p, including
support for y-or-n-p-use-read-key, but evidently it doesn't, which is
surprising, I think.)




Information forwarded to bug-gnu-emacs <at> gnu.org:
bug#58808; Package emacs. (Thu, 27 Oct 2022 11:02:01 GMT) Full text and rfc822 format available.

Message #11 received at 58808 <at> debbugs.gnu.org (full text, mbox):

From: meedstrom <at> teknik.io
To: "Eli Zaretskii" <eliz <at> gnu.org>, "Stefan Monnier" <monnier <at> iro.umontreal.ca>
Cc: 58808 <at> debbugs.gnu.org
Subject: Re: bug#58808: map-y-or-n-p should use read-key, not read-event
Date: Thu, 27 Oct 2022 11:01:15 +0000
October 27, 2022 at 5:58 AM, "Eli Zaretskii" wrote:
 
> Isn't there some translation map that could help you?

I have tried the remap in all of these:

- input-decode-map
- key-translation-map
- function-key-map
- all of the above simultaneously

I don't mind letting C-g be a separate key just for unfreezing Emacs, but in all other cases it seems right for an Escape remap to Just Work.

Martin





Information forwarded to bug-gnu-emacs <at> gnu.org:
bug#58808; Package emacs. (Thu, 27 Oct 2022 15:40:01 GMT) Full text and rfc822 format available.

Message #14 received at 58808 <at> debbugs.gnu.org (full text, mbox):

From: Stefan Monnier <monnier <at> iro.umontreal.ca>
To: Eli Zaretskii <eliz <at> gnu.org>
Cc: 58808 <at> debbugs.gnu.org, meedstrom <at> teknik.io
Subject: Re: bug#58808: map-y-or-n-p should use read-key, not read-event
Date: Thu, 27 Oct 2022 11:39:10 -0400
>> I found that map-y-or-n-p uses read-event, not read-key (still the
>> case in master as of 2022-10-27).  Will you accept a patch if I try
>> to rewrite it?
[...]
> Isn't there some translation map that could help you?

No, `read-event` is the low-level function that gives access to the
actual untranslated events.  I think `map-y-or-n-p` should be changed
similarly to `y-or-n-p` to use either `read-key` or the minibuffer
(probably obeying `y-or-n-p-use-read-key`).


        Stefan





Information forwarded to bug-gnu-emacs <at> gnu.org:
bug#58808; Package emacs. (Thu, 09 Feb 2023 00:00:02 GMT) Full text and rfc822 format available.

Message #17 received at 58808 <at> debbugs.gnu.org (full text, mbox):

From: Stefan Monnier <monnier <at> iro.umontreal.ca>
To: Jeremy Bryant <jb <at> jeremybryant.net>
Cc: Eli Zaretskii <eliz <at> gnu.org>, 58808 <at> debbugs.gnu.org
Subject: Re: bug#58808: map-y-or-n-p should use read-key, not read-event
Date: Wed, 08 Feb 2023 18:59:28 -0500
> In order to work on this, please could you confirm the suggested change
> below from October is still the recommended one, to work on a patch
> along the lines below?

Nothing has changed in this regard, indeed, so my comment from last year
is still as valid as ever :-)


        Stefan





Information forwarded to bug-gnu-emacs <at> gnu.org:
bug#58808; Package emacs. (Thu, 09 Feb 2023 03:39:04 GMT) Full text and rfc822 format available.

Message #20 received at 58808 <at> debbugs.gnu.org (full text, mbox):

From: Jeremy Bryant <jb <at> jeremybryant.net>
To: Stefan Monnier <monnier <at> iro.umontreal.ca>
Cc: 58808 <at> debbugs.gnu.org
Subject: Re: bug#58808: map-y-or-n-p should use read-key, not read-event
Date: Wed, 08 Feb 2023 22:51:11 +0000
Stefan Monnier <monnier <at> iro.umontreal.ca> writes:
Hi Stefan,

In order to work on this, please could you confirm the suggested change
below from October is still the recommended one, to work on a patch
along the lines below?

Jeremy

>>> I found that map-y-or-n-p uses read-event, not read-key (still the
>>> case in master as of 2022-10-27).  Will you accept a patch if I try
>>> to rewrite it?
> [...]
>> Isn't there some translation map that could help you?
>
> No, `read-event` is the low-level function that gives access to the
> actual untranslated events.  I think `map-y-or-n-p` should be changed
> similarly to `y-or-n-p` to use either `read-key` or the minibuffer
> (probably obeying `y-or-n-p-use-read-key`).
>
>
>         Stefan




This bug report was last modified 1 year and 70 days ago.

Previous Next


GNU bug tracking system
Copyright (C) 1999 Darren O. Benham, 1997,2003 nCipher Corporation Ltd, 1994-97 Ian Jackson.