From: martin rudalics <rudalics@gmx.at>
To: Juri Linkov <juri@linkov.net>
Cc: 32672@debbugs.gnu.org
Subject: bug#32672: 27.0.50; image resize on window resizing
Date: Sun, 16 Sep 2018 11:10:38 +0200 [thread overview]
Message-ID: <5B9E1E0E.7070805@gmx.at> (raw)
In-Reply-To: <87pnxexr2m.fsf@mail.linkov.net>
[-- Attachment #1: Type: text/plain, Size: 846 bytes --]
> I agree that the buffer list is more global than a window, but OTOH
> it makes sense to use buffer-local hook for a buffer to get notified
> when it comes to the top of the buffer list. So this would be a good thing
> to have, unless there is another hook that gets called when a buffer
> becomes the current buffer, or at least displayed in a window.
I try to fix the problem you mentioned earlier, namely that
> > it's called only when navigating away from the
> > image-mode buffer, but not when coming back to the image-mode buffer, e.g.
> > `C-x <left>', then resize the window, then type `C-x <right>',
> > it's not called. Also it's not called in another direction:
> > `C-x <right>', then resize the window, then type `C-x <left>'.
Please tell me if the attached patch works and what else should be
done.
Thanks, martin
[-- Attachment #2: buffer-list-update-hook.diff --]
[-- Type: text/plain, Size: 2719 bytes --]
--- a/lisp/window.el
+++ b/lisp/window.el
@@ -4301,9 +4301,9 @@ set-window-buffer-start-and-point
(setq window (window-normalize-window window t))
(let ((selected (eq window (selected-window)))
(current (eq (window-buffer window) (current-buffer))))
- (set-window-buffer window buffer)
(when (and selected current)
(set-buffer buffer))
+ (set-window-buffer window buffer)
(when start
;; Don't force window-start here (even if POINT is nil).
(set-window-start window start t))
diff --git a/src/window.c b/src/window.c
index 409b01f..33e1975 100644
--- a/src/window.c
+++ b/src/window.c
@@ -3573,40 +3573,36 @@ depends on the value of (window-start WINDOW), so if calling this
This function runs `window-scroll-functions' before running
`window-configuration-change-hook'. */)
- (register Lisp_Object window, Lisp_Object buffer_or_name, Lisp_Object keep_margins)
+ (Lisp_Object window, Lisp_Object buffer_or_name, Lisp_Object keep_margins)
{
- register Lisp_Object tem, buffer;
- register struct window *w = decode_live_window (window);
+ Lisp_Object old_buffer, new_buffer;
+ struct window *w = decode_live_window (window);
XSETWINDOW (window, w);
- buffer = Fget_buffer (buffer_or_name);
- CHECK_BUFFER (buffer);
- if (!BUFFER_LIVE_P (XBUFFER (buffer)))
+ old_buffer = w->contents;
+ new_buffer = Fget_buffer (buffer_or_name);
+ CHECK_BUFFER (new_buffer);
+ if (!BUFFER_LIVE_P (XBUFFER (new_buffer)))
error ("Attempt to display deleted buffer");
- tem = w->contents;
- if (NILP (tem))
- error ("Window is deleted");
- else
+ if (!EQ (old_buffer, new_buffer))
{
- if (!EQ (tem, buffer))
- {
- if (EQ (w->dedicated, Qt))
- /* WINDOW is strongly dedicated to its buffer, signal an
- error. */
- error ("Window is dedicated to `%s'", SDATA (BVAR (XBUFFER (tem), name)));
- else
- /* WINDOW is weakly dedicated to its buffer, reset
- dedication. */
- wset_dedicated (w, Qnil);
-
- call1 (Qrecord_window_buffer, window);
- }
+ if (EQ (w->dedicated, Qt))
+ /* WINDOW is strongly dedicated to its buffer, signal an
+ error. */
+ error ("Window is dedicated to `%s'", SDATA (BVAR (XBUFFER (old_buffer), name)));
+ else
+ /* WINDOW is weakly dedicated to its buffer, reset
+ dedication. */
+ wset_dedicated (w, Qnil);
unshow_buffer (w);
}
- set_window_buffer (window, buffer, true, !NILP (keep_margins));
+ set_window_buffer (window, new_buffer, true, !NILP (keep_margins));
+
+ if (!EQ (old_buffer, new_buffer))
+ call1 (Qrecord_window_buffer, window);
return Qnil;
}
next prev parent reply other threads:[~2018-09-16 9:10 UTC|newest]
Thread overview: 51+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-09-09 15:54 bug#32672: 27.0.50; image resize on window resizing Juri Linkov
2018-09-11 23:53 ` Juri Linkov
2018-09-12 6:33 ` martin rudalics
2018-09-12 23:18 ` Juri Linkov
2018-09-13 7:46 ` martin rudalics
2018-09-13 23:20 ` Juri Linkov
2018-09-14 8:33 ` martin rudalics
2018-09-15 23:35 ` Juri Linkov
2018-09-16 9:10 ` martin rudalics [this message]
2018-09-16 23:49 ` Juri Linkov
2018-09-17 6:46 ` martin rudalics
2018-09-17 22:35 ` Juri Linkov
2018-09-19 8:22 ` martin rudalics
2018-09-19 23:15 ` Juri Linkov
2018-09-20 7:34 ` martin rudalics
2018-09-20 23:15 ` Juri Linkov
2018-09-21 6:34 ` martin rudalics
2018-09-22 22:15 ` Juri Linkov
2018-09-23 8:26 ` martin rudalics
2018-09-23 20:39 ` Juri Linkov
2018-09-24 8:22 ` martin rudalics
2018-09-24 8:35 ` Eli Zaretskii
2018-09-24 12:25 ` martin rudalics
2018-09-24 12:46 ` Eli Zaretskii
2018-09-24 17:37 ` martin rudalics
2018-09-24 17:53 ` Eli Zaretskii
2018-09-25 7:26 ` martin rudalics
2018-09-25 9:19 ` Eli Zaretskii
2018-09-25 17:56 ` martin rudalics
2018-09-25 18:31 ` Eli Zaretskii
2018-09-24 18:38 ` Juri Linkov
2018-09-24 19:31 ` Eli Zaretskii
2018-09-25 7:27 ` martin rudalics
2018-09-25 19:24 ` Juri Linkov
2018-09-26 8:51 ` martin rudalics
2018-10-27 19:38 ` Juri Linkov
2018-10-28 8:59 ` martin rudalics
2018-09-24 18:31 ` Juri Linkov
2018-09-25 7:27 ` martin rudalics
2018-12-26 23:42 ` Juri Linkov
2018-12-27 9:36 ` martin rudalics
2018-12-27 21:41 ` Juri Linkov
2018-12-28 8:34 ` martin rudalics
2018-12-27 15:48 ` Eli Zaretskii
2018-12-27 20:58 ` Juri Linkov
2018-12-28 4:51 ` Eli Zaretskii
2019-09-26 13:27 ` Lars Ingebrigtsen
2019-11-27 21:53 ` Juri Linkov
2019-11-28 9:20 ` martin rudalics
2019-11-28 22:50 ` Juri Linkov
2019-11-29 9:24 ` martin rudalics
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=5B9E1E0E.7070805@gmx.at \
--to=rudalics@gmx.at \
--cc=32672@debbugs.gnu.org \
--cc=juri@linkov.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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.