GNU bug report logs -
#7728
24.0.50; GDB backtrace from abort
Previous Next
Reported by: "Drew Adams" <drew.adams <at> oracle.com>
Date: Fri, 24 Dec 2010 16:51:02 UTC
Severity: normal
Found in version 24.0.50
Done: Chong Yidong <cyd <at> gnu.org>
Bug is archived. No further changes may be made.
Full log
View this message in rfc822 format
> > How could it? For example, Drew's code that causes this
> > crash does this:
> > (save-window-excursion (select-frame frame)
> > (or (eq major-mode 'image-mode)
> > image-minor-mode))
FWIW, that is not the part of the code that gets executed when there is a crash.
However, the branch of the `if' that is executed when there is a crash also has
a similar `save-window-excursion':
(save-window-excursion
(select-frame frame)
(setq empty-buf-p (and (= (point-min) (point-max))
(one-window-p (selected-window)))
specbuf-p (and empty-buf-p
(special-display-p
(buffer-name (window-buffer))))))
> > Are you saying tha this isn't kosher, because the body of
> > save-window-excursion is not allowed to select a different frame?
>
> Admittedly, I think the above code is mistaken. It kind of reminds me
> of the infamous (save-excursion (set-buffer) ...), although in worse
> since, like Martin, I despise save-window-excursion.
And just what code do you suggest for going off to do something on a different
frame and returning? AFAIK we do not have a `save-frame-excursion'. I have
always considered (and seen) `save-window-excursion' to be the way to do this.
This bug report was last modified 12 years and 357 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.