unofficial mirror of help-gnu-emacs@gnu.org
 help / color / mirror / Atom feed
From: "Ehud Karni" <ehud@unix.mvs.co.il>
Cc: knipknap@jabber.org, help-gnu-emacs@gnu.org, emacs-devel@gnu.org
Subject: Re: New balance-windows (Was Re: Making the width of three windows equal)
Date: Mon, 8 Aug 2005 12:27:06 +0300	[thread overview]
Message-ID: <200508080927.j789R6Ss007055@beta.mvs.co.il> (raw)
In-Reply-To: <E1E1okJ-0007zE-Bc@fencepost.gnu.org> (message from Richard M. Stallman on Sun, 07 Aug 2005 13:15:35 -0400)

On Sun, 07 Aug 2005 13:15:35 -0400, Richard M. Stallman <rms@gnu.org> wrote:
>
> Why do you think this is better than the current balance-windows function?

Two reasons: 1. because it fails in a complex windows arrangement.
  2. I added balancing horizontally option (by prefix argument).

Here are some examples of balancing complex windows configuration
(the number in each window is the of lines in the window):

    After `balance-windows'           After my new function
    +-------+-------+-------+        +-------+-------+-------+
    |  9    |       |       |        |       |       |       |
    |       |       |  19   |        |  15   |       |  20   |
    +-------+       |       |        |       |       |       |
    |       |  29   |       |        +-------+  30   |       |
    |  19   |       +-------+        |       |       +-------+
    |       |       |       |        |  15   |       |       |
    |       |       |       |        |       |       |       |
    +----+--+-------+  19   |        +----+--+-------+  20   |
    |    |  |       |       |        |    |  |       |       |
    | 19 |  |       |       |        | 14 |  |       |       |
    |    |  |       +-------+        |    |  |       +-------+
    |    |  |  32   |       |        +----+--+  31   |       |
    +----+--+       |       |        |       |       |       |
    |       |       |  22   |        | 15    |       |  20   |
    | 12    |       |       |        |       |       |       |
    |       |       |       |        |       |       |       |
    +-------+-------+-------+        +-------+-------+-------+

In the above case mine is better.


    After `balance-windows'           After my new function
    +-----------+-----------+        +----------+------------+
    |           |   10      |        |          |     6      |
    |           |           |        |          +------------+
    |           +-----------+        |    19    |     6      |
    |   32      |   10      |        |          +------------+
    |           |           |        |          |     5      |
    |           +-----------+        +------+---+---+--------|
    |           |   10      |        |      |       |        |
    |           |           |        |  18  |       |  18    |
    +------+----+---+-------+        |      |       |        |
    |  10  |        |  10   |        |      |       |        |
    |      |        |       |        +------+-------+--------|
    +------+--------+-------+        |                       |
    |                       |        |         17            |
    |          12           |        |                       |
    |                       |        |                       |
    +-----------------------+        +-----------------------+

In this case the 22.0.50 balance-windows is better.


If 2 more splits are done, both functions fails:

    After `balance-windows'           After my new function
    +-----------+-----------+        +-----------+-----------+
    |           |    8      |        |           |   10      |
    |   17      |           |        |   14      |           |
    |           +-----------+        |           +-----------+
    |           |           |        +-----------+   10      |
    +-----------+           |        |           |           |
    |           |   17      |        |           +-----+-----+
    |   14      |           |        |   17      |     |     |
    |           +-----+-----+        |           | 10  | 10  |
    |           |  4  | 4   |        |           |     |     |
--> +------+----+---+-+-----+  -V-   +------+----+---+-+-----+ <---
    |   8  |        |  8    |        |      |        |       |
    |      |        |       |        |  12  |  12    |  12   |
    +------+--------+-------+        |      |        |       |
    |                       |        +------+--------+-------+
    |          14           |        |          10           |
    |                       |        |                       |
    +-----------------------+        +-----------------------+

The reason to the failure is that in this configuration the
vertical border (-V-) , although full length border, can NOT
be moved by resizing of any window.

I have looked into `enlarge-window' and I it is too complex for
me to fix it.

So, I'll work on my function some more. My proposed logic (for
vertical balancing) is to group the windows according to the
right edge AND the left edge (every window will be in 2 groups)
sort the groups by number of windows in each group, compute the
new size for this group and resize the windows in this group.
Now, repeat the whole process but ignore all the windows that
have already been resized. This approach is using ONLY the
geometry of the windows configuration. It sure will fail when
there is an unmovable edge.

Ehud.


--
 Ehud Karni           Tel: +972-3-7966-561  /"\
 Mivtach - Simon      Fax: +972-3-7966-667  \ /  ASCII Ribbon Campaign
 Insurance agencies   (USA) voice mail and   X   Against   HTML   Mail
 http://www.mvs.co.il  FAX:  1-815-5509341  / \
 GnuPG: 98EA398D <http://www.keyserver.net/>    Better Safe Than Sorry

  reply	other threads:[~2005-08-08  9:27 UTC|newest]

Thread overview: 30+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2005-08-03  0:47 Making the width of three windows equal Samuel
2005-08-03  1:01 ` Pascal Bourguignon
2005-08-03  2:13   ` Samuel
2005-08-03  3:11     ` Pascal Bourguignon
2005-08-06 11:59       ` New balance-windows (Was Re: Making the width of three windows equal) Ehud Karni
2005-08-06 13:27         ` New balance-windows Ehud Karni
     [not found]         ` <mailman.2758.1123335041.20277.help-gnu-emacs@gnu.org>
2005-08-06 16:42           ` Pascal Bourguignon
2005-08-07 17:15         ` New balance-windows (Was Re: Making the width of three windows equal) Richard M. Stallman
2005-08-08  9:27           ` Ehud Karni [this message]
2005-08-09  0:27             ` Richard M. Stallman
2005-08-10  0:05             ` New balance-windows Stefan Monnier
2005-08-10  1:48               ` Stefan Monnier
     [not found]             ` <mailman.3158.1123633927.20277.help-gnu-emacs@gnu.org>
2005-08-21  0:33               ` David Combs
     [not found]           ` <mailman.2979.1123493766.20277.help-gnu-emacs@gnu.org>
2005-08-08 17:55             ` Pascal Bourguignon
     [not found]         ` <mailman.2888.1123436059.20277.help-gnu-emacs@gnu.org>
2005-08-07 18:31           ` Pascal Bourguignon
     [not found]       ` <mailman.2754.1123329756.20277.help-gnu-emacs@gnu.org>
2005-08-06 16:39         ` Pascal Bourguignon
2005-08-06 16:58           ` Lennart Borgman
     [not found]           ` <mailman.2773.1123347813.20277.help-gnu-emacs@gnu.org>
2005-08-06 20:45             ` Pascal Bourguignon
2005-08-06 21:14               ` Lennart Borgman
     [not found]               ` <mailman.2796.1123363907.20277.help-gnu-emacs@gnu.org>
2005-08-07 18:23                 ` Pascal Bourguignon
2005-08-07 18:59                   ` Lennart Borgman
     [not found]                   ` <mailman.2899.1123441421.20277.help-gnu-emacs@gnu.org>
2005-08-07 20:42                     ` Pascal Bourguignon
2005-08-06 21:05           ` Ehud Karni
2005-08-07  2:17           ` Lennart Borgman
2005-08-08  9:36             ` Ehud Karni
2005-08-08  9:47               ` Lennart Borgman
     [not found]             ` <mailman.2988.1123495783.20277.help-gnu-emacs@gnu.org>
2005-08-08 10:18               ` David Kastrup
2005-08-08 11:18                 ` Ehud Karni
2005-08-08 12:05                   ` Lennart Borgman
     [not found]                 ` <mailman.3002.1123500982.20277.help-gnu-emacs@gnu.org>
2005-08-08 18:11                   ` Pascal Bourguignon

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=200508080927.j789R6Ss007055@beta.mvs.co.il \
    --to=ehud@unix.mvs.co.il \
    --cc=emacs-devel@gnu.org \
    --cc=help-gnu-emacs@gnu.org \
    --cc=knipknap@jabber.org \
    /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.
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).