unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#54084: 28.0.91; Regression: can't create empty image buffer
@ 2022-02-21  8:21 Corwin Brust
  2022-02-21 12:57 ` Eli Zaretskii
  0 siblings, 1 reply; 6+ messages in thread
From: Corwin Brust @ 2022-02-21  8:21 UTC (permalink / raw)
  To: 54084

Under Emacs -Q

1. switch to a new buffer, e.g. C-x b *foo* RET
2. M-x image-mode RET

3. Insert the following text and press C-c C-c

<svg width="400" height="400">
  <rect x="100" y="100" width="200" height="100"
        fill="none" stroke="blue" stroke-width="2"/>
</svg>

In Emacs 27.2 the outline of a rectangle is displayed as an image.

In Emacs 28.0.91 an error is emitted at step 2:

Debugger entered--Lisp error: (wrong-type-argument stringp nil)
  image-mode()
  funcall-interactively(image-mode)
  command-execute(image-mode record)
  execute-extended-command(nil "image-mode" "image-mod")
  funcall-interactively(execute-extended-command nil "image-mode" "image-mod")
  command-execute(execute-extended-command)

Furthermore, inserting the text and pressing C-c C-c will do nothing
because the error interrupts the mode activation. (A subsequent M-x
image-mode RET after pasting in the snippet works.)

Ergo, it is not possible to create an empty buffer in image-mode, as
was possible in Emacs 27.2 and before.


In GNU Emacs 28.0.91 (build 6, x86_64-w64-mingw32)
 of 2022-02-05 built on AVALON
Repository revision: 821c240075e3b850a61207d18d520126292421ce
Repository branch: emacs-28-nt-dist-build
Windowing system distributor 'Microsoft Corp.', version 10.0.19043
System Description: Microsoft Windows 10 Home (v10.0.2009.19043.1566)

Configured using:
 'configure --with-json --without-dbus --with-native-compilation
 --without-compress-install CFLAGS=-O2'

Configured features:
ACL GIF GMP GNUTLS HARFBUZZ JPEG JSON LCMS2 LIBXML2 MODULES NATIVE_COMP
NOTIFY W32NOTIFY PDUMPER PNG RSVG SOUND THREADS TIFF TOOLKIT_SCROLL_BARS
XPM ZLIB

Important settings:
  value of $LC_CTYPE: en_US.UTF-8
  value of $LANG: ENU
  locale-coding-system: cp1252

Major mode: Image[svg]

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 rfc822 mml mml-sec epa
derived epg rfc6068 epg-config gnus-util rmail rmail-loaddefs
auth-source 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 cl-seq help-fns radix-tree time-date subr-x cl-print debug
backtrace help-mode find-func image-mode dired dired-loaddefs exif
cl-loaddefs cl-lib cus-start cus-load iso-transl tooltip eldoc paren
electric uniquify ediff-hook vc-hooks lisp-float-type elisp-mode 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 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 w32notify
w32 lcms2 multi-tty make-network-process native-compile emacs)

Memory information:
((conses 16 87195 11377)
 (symbols 48 8253 0)
 (strings 32 24379 1444)
 (string-bytes 1 764439)
 (vectors 16 14960)
 (vector-slots 8 313276 16186)
 (floats 8 38 231)
 (intervals 56 402 2)
 (buffers 992 13))





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

* bug#54084: 28.0.91; Regression: can't create empty image buffer
  2022-02-21  8:21 bug#54084: 28.0.91; Regression: can't create empty image buffer Corwin Brust
@ 2022-02-21 12:57 ` Eli Zaretskii
  2022-02-21 13:58   ` Corwin Brust
       [not found]   ` <CAJf-WoSU0e4dEmVTH=wxX5=UywqP0Vy7emhXqv4vXaKtVmPMFg@mail.gmail.com>
  0 siblings, 2 replies; 6+ messages in thread
From: Eli Zaretskii @ 2022-02-21 12:57 UTC (permalink / raw)
  To: Corwin Brust; +Cc: 54084

> From: Corwin Brust <corwin@bru.st>
> Date: Mon, 21 Feb 2022 02:21:32 -0600
> 
> Under Emacs -Q
> 
> 1. switch to a new buffer, e.g. C-x b *foo* RET
> 2. M-x image-mode RET
> 3. Insert the following text and press C-c C-c
> 
> <svg width="400" height="400">
>   <rect x="100" y="100" width="200" height="100"
>         fill="none" stroke="blue" stroke-width="2"/>
> </svg>
> 
> In Emacs 27.2 the outline of a rectangle is displayed as an image.
> 
> In Emacs 28.0.91 an error is emitted at step 2:
> 
> Debugger entered--Lisp error: (wrong-type-argument stringp nil)
>   image-mode()
>   funcall-interactively(image-mode)
>   command-execute(image-mode record)
>   execute-extended-command(nil "image-mode" "image-mod")
>   funcall-interactively(execute-extended-command nil "image-mode" "image-mod")
>   command-execute(execute-extended-command)

It's a feature, see bug#16062.  (It misfired when the empty buffer
wasn't visiting a file, but I've now fixed that on the release
branch.)

> Furthermore, inserting the text and pressing C-c C-c will do nothing
> because the error interrupts the mode activation. (A subsequent M-x
> image-mode RET after pasting in the snippet works.)
> 
> Ergo, it is not possible to create an empty buffer in image-mode, as
> was possible in Emacs 27.2 and before.

You are supposed to insert the data, and then turn on image-mode.  We
don't support image-mode in empty buffers, because that makes it
impossible to detect the image type, and thus leads to complications
down the road.

Thanks.





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

* bug#54084: 28.0.91; Regression: can't create empty image buffer
  2022-02-21 12:57 ` Eli Zaretskii
@ 2022-02-21 13:58   ` Corwin Brust
  2022-02-21 14:03     ` Eli Zaretskii
       [not found]   ` <CAJf-WoSU0e4dEmVTH=wxX5=UywqP0Vy7emhXqv4vXaKtVmPMFg@mail.gmail.com>
  1 sibling, 1 reply; 6+ messages in thread
From: Corwin Brust @ 2022-02-21 13:58 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: 54084

tags 54084 + fixed
close 54084 28.0.91
# thanks for the prompt fix
bye

On Mon, Feb 21, 2022 at 6:57 AM Eli Zaretskii <eliz@gnu.org> wrote:
>
> It's a feature, see bug#16062.  (It misfired when the empty buffer
> wasn't visiting a file, but I've now fixed that on the release
> branch.)
>

This has my stuff working again; much appreciated.

I have (tried to) mark the bug as done/fixed but please LMK if that wasn't TRT.





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

* bug#54084: 28.0.91; Regression: can't create empty image buffer
       [not found]   ` <CAJf-WoSU0e4dEmVTH=wxX5=UywqP0Vy7emhXqv4vXaKtVmPMFg@mail.gmail.com>
@ 2022-02-21 14:00     ` Eli Zaretskii
  2022-02-21 14:16       ` Corwin Brust
  0 siblings, 1 reply; 6+ messages in thread
From: Eli Zaretskii @ 2022-02-21 14:00 UTC (permalink / raw)
  To: Corwin Brust; +Cc: 54084

[Please use Reply All, so that the bug tracker remains on the CC.]

> From: Corwin Brust <corwin@bru.st>
> Date: Mon, 21 Feb 2022 07:41:36 -0600
> 
> On Mon, Feb 21, 2022 at 6:57 AM Eli Zaretskii <eliz@gnu.org> wrote:
> >
> > It's a feature, see bug#16062.  (It misfired when the empty buffer
> > wasn't visiting a file, but I've now fixed that on the release
> > branch.)
> 
> Is there a way to disable this feature?

Why is that needed?  Turning on image-mode in an empty buffer is a
pretty strange thing to do, or at least a rare thing.

> In my case the image type won't change, I'd be fine hard-coding
> that.
> 
> >
> > You are supposed to insert the data, and then turn on image-mode.  We
> > don't support image-mode in empty buffers, because that makes it
> > impossible to detect the image type, and thus leads to complications
> > down the road.
> >
> > Thanks.
> 
> I'm not sure how to avoid this error when I create a new buffer in a
> mode derived from image mode.

Can't you use ignore-errors?

> Is there an alternative you can recommend to creating my own
> "one-off" version of image mode and deriving from that?  In my case,
> I have created an SVG sketching mode and have been reusing,
> e.g. "canvas" resizing logic from image-mode for a couple of years
> without issue.
> 
> TIA for any hints.

How about delaying the mode switch until the user inserted something?





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

* bug#54084: 28.0.91; Regression: can't create empty image buffer
  2022-02-21 13:58   ` Corwin Brust
@ 2022-02-21 14:03     ` Eli Zaretskii
  0 siblings, 0 replies; 6+ messages in thread
From: Eli Zaretskii @ 2022-02-21 14:03 UTC (permalink / raw)
  To: Corwin Brust; +Cc: 54084-done

> From: Corwin Brust <corwin@bru.st>
> Date: Mon, 21 Feb 2022 07:58:39 -0600
> Cc: 54084@debbugs.gnu.org
> 
> This has my stuff working again; much appreciated.

Thanks, closing.

P.S. Your attempts to close didn't work, probably because you didn't
add a BCC to control@debbugs.gnu.org.





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

* bug#54084: 28.0.91; Regression: can't create empty image buffer
  2022-02-21 14:00     ` Eli Zaretskii
@ 2022-02-21 14:16       ` Corwin Brust
  0 siblings, 0 replies; 6+ messages in thread
From: Corwin Brust @ 2022-02-21 14:16 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: 54084

On Mon, Feb 21, 2022 at 8:00 AM Eli Zaretskii <eliz@gnu.org> wrote:
>
> [Please use Reply All, so that the bug tracker remains on the CC.]

Sorry about that.

> > From: Corwin Brust <corwin@bru.st>
> > Date: Mon, 21 Feb 2022 07:41:36 -0600
> >
> > Is there a way to disable this feature?
>
> Why is that needed?  Turning on image-mode in an empty buffer is a
> pretty strange thing to do, or at least a rare thing.

Noted, thanks.  FTR, for dungeon I have several modes that are derived
from image-mode, e.g. for displaying graphical character sheets,
combat status information, and maps.  I also have a point-and-click
drawing mode for creating/editing "tile-sets" and composing (e.g.)
maps for dungeon levels using these "named SVG fragments".

>
> Can't you use ignore-errors?
>
> How about delaying the mode switch until the user inserted something?

I will look into these options. (So far, the change you made seems to
have all my stuff working again per the release branch.)





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

end of thread, other threads:[~2022-02-21 14:16 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-02-21  8:21 bug#54084: 28.0.91; Regression: can't create empty image buffer Corwin Brust
2022-02-21 12:57 ` Eli Zaretskii
2022-02-21 13:58   ` Corwin Brust
2022-02-21 14:03     ` Eli Zaretskii
     [not found]   ` <CAJf-WoSU0e4dEmVTH=wxX5=UywqP0Vy7emhXqv4vXaKtVmPMFg@mail.gmail.com>
2022-02-21 14:00     ` Eli Zaretskii
2022-02-21 14:16       ` Corwin Brust

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