From: Dmitry Gutov <dgutov@yandex.ru>
To: martin rudalics <rudalics@gmx.at>
Cc: 11810@debbugs.gnu.org, emacs-devel <emacs-devel@gnu.org>
Subject: bug#11810: 24.1.50; `vc-diff' shrinks pre-existing window
Date: Mon, 02 Jul 2012 17:33:03 +0400 [thread overview]
Message-ID: <4FF1A30F.4090806__25723.6597747125$1341236028$gmane$org@yandex.ru> (raw)
In-Reply-To: <4FF146F4.1080103@gmx.at>
On 02.07.2012 11:00, martin rudalics wrote:
> > From what I understand in `window-combination-resize' docstring, its
> > value decides whether splitting a window borrows space only from
> > adjacent window, or from all windows in a "combination" (so they all get
> > resized). For that to happen, a window splitting should occur, right?
> > But when we're displaying a buffer in pre-existing window, no splitting
> > occurs, just resizing.
> > And `even-window-heights' controls whether it should be resized at all.
>
> IIUC, the case we're talking about is that of a split frame where one
> window gets reused. Now, with `window-combination-resize' non-nil,
> `display-buffer' practically always makes a new window in such a case
> because it can steal space from both existing windows. Quitting or
> deleting the new window will restore the sizes of the original windows
> regardless of whether `temp-buffer-resize-mode' has been used or not.
I see. Still, I'm primarily interested in the scenario where the windows
don't get split (with appropriate split-*-threshold values), and in this
case `even-window-heights' value has effect.
Note that if the widow does get split, `vc-diff' behaves okay, because
`q' deletes the used window, and the configuration becomes as it was (at
least with `window-combination-resize' nil).
> >> We could simply remove the `temp-buffer-resize-mode' check in
> >> `quit-window'. I hardly understand what implications this might have.
> >
> > I think it's just trying to making sure that (nth 3 quad) is of the
> > right type, so that the comparison doesn't blow up.
>
> No (at least not as far as I originally conceived it). My idea was as
> follows:
>
> (1) When `temp-buffer-resize-mode' is non-nil and the window size has
> changed, chances are that the change was caused by
> `temp-buffer-resize-mode' so it seems pretty safe to rescind that
> change.
I don't think so. Like I said, the value saved in 'quit-restore
parameter is the same in this case, whether `temp-buffer-resize-mode' is
on or not.
So even if `temp-buffer-resize-mode' is on, we can't confidently decide
that the value was set by it.
> (2) When `temp-buffer-resize-mode' is nil and the window size has
> changed, the change was probably due to some manual intervention
> probably needed to see more of a buffer originally present and it
> seems better to leave that change alone.
>
> But maybe my conception was flawed.
Would it be harder to *not set* the 'quit-restore parameter in cases
when we don't want the configuration restored, instead?
But as it is, I'm not sure what's the problem with always using its
value when present. I've been running Emacs with the tiny patch I posted
for a couple of days, and it seems fine.
Could you describe the scenario with "seeing more of a buffer originally
present"?
> > If I enable temp-buffer-resize-mode before doing vc-diff, after I quit
> > the window, its size does get restored.
>
> It should be sufficient to set the variable `temp-buffer-resize-mode'
> locally in that buffer.
Yes, but that's not what I meant.
> > Also, (nth 3 quad) is integer at that point even temp-buffer-resize-mode
> > is disabled, so the mode check doesn't make sense.
> > To be safe, though, we could replace it with `integerp' call.
>
> Yes, but the `condition-case' should handle any problems with it.
Don't we want to execute the code following (when resize ...) either way?
> In any case, we have to cater for the case where people (I'm not sure
> whether I got Andreas right) want to disable adjusting the window in the
> first place. So I really think we should simply special-case this by
> providing some option like `vc-fit-diff-window-to-buffer' and adjust the
> window only if that variable has a non-nil value. If it's non-nil, we
> can either
I'm fine with either behavior (not resizing or properly restoring), but
`vc-diff' is not the only culprit. `vc-log-print' also does the
shrinking, although it's harder to observe.
If there will be a variable, I don't see why it should be local to VC.
Are there users who would want windows shrunk by VC, but not other
packages, or vice versa?
> (1) set `temp-buffer-resize-mode' locally in such buffers, or
>
> (2) provide yet another variable which, when set, causes `quit-window'
> to re-resize the window (we could misuse `even-window-heights' for
> this purpose), or
That won't do if the original windows sizes were not even, like in the
SO question linked to previously.
> (3) re-resize the window as in your patch.
-- Dmitry
next prev parent reply other threads:[~2012-07-02 13:33 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-06-28 19:22 bug#11810: 24.1.50; `vc-diff' shrinks pre-existing window Dmitry Gutov
2012-06-28 22:32 ` Andreas Schwab
2012-06-28 22:45 ` Dmitry Gutov
2012-06-29 7:12 ` Andreas Schwab
2012-06-29 7:12 ` martin rudalics
2012-06-29 22:39 ` Dmitry Gutov
2012-06-30 9:09 ` martin rudalics
2012-06-30 21:34 ` Juanma Barranquero
2012-07-01 9:06 ` martin rudalics
2012-06-30 23:18 ` Dmitry Gutov
2012-07-01 9:06 ` martin rudalics
[not found] ` <4FF05DC0.4080609@yandex.ru>
[not found] ` <4FF146F4.1080103@gmx.at>
2012-07-02 13:33 ` Dmitry Gutov [this message]
[not found] ` <4FF1A30F.4090806@yandex.ru>
2012-07-02 16:32 ` martin rudalics
[not found] ` <4FF1CD2C.5000704@gmx.at>
2012-07-02 20:39 ` Dmitry Gutov
[not found] ` <4FF206F5.4030101@yandex.ru>
2012-07-03 7:14 ` martin rudalics
2012-07-03 12:48 ` Dmitry Gutov
2012-07-03 16:40 ` martin rudalics
2012-07-03 18:56 ` Dmitry Gutov
2012-07-04 9:18 ` martin rudalics
2012-07-04 16:12 ` Dmitry Gutov
2012-07-05 9:53 ` martin rudalics
2012-07-05 23:19 ` Dmitry Gutov
2012-07-06 6:36 ` martin rudalics
2012-07-06 12:25 ` Dmitry Gutov
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
List information: https://www.gnu.org/software/emacs/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to='4FF1A30F.4090806__25723.6597747125$1341236028$gmane$org@yandex.ru' \
--to=dgutov@yandex.ru \
--cc=11810@debbugs.gnu.org \
--cc=emacs-devel@gnu.org \
--cc=rudalics@gmx.at \
/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 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).