Because we defer actually resizing applications (calling TIOCSWINSZ)
authornicm <nicm@openbsd.org>
Wed, 31 May 2017 10:15:51 +0000 (10:15 +0000)
committernicm <nicm@openbsd.org>
Wed, 31 May 2017 10:15:51 +0000 (10:15 +0000)
commitdcf9d915e6c43af32189d8ce8fbace8d1e7bede8
tree727da831275185c2386b8333b7051d7176122ebe
parentdd3e82137f4de80314609ac89515a66d668adcdc
Because we defer actually resizing applications (calling TIOCSWINSZ)
until the end of the server loop, tmux may have gone through several
internal resizes in between. This can be a problem if the final size is
the same as the initial size (what the application things it currently
is), because the application may choose not to redraw, assuming the
screen state is unchanged, when in fact tmux has thrown away parts of
the screen, assuming the application will redraw them.

To avoid this, do an extra resize if the new size is the same size as
the initial size. This should force the application to redraw when tmux
needs it to, while retaining the benefits of deferring (so we now resize
at most two times instead of at most one - and only two very rarely).

Fixes a problem with break-pane and zoomed panes reported by Michal
Mazurek.
usr.bin/tmux/server-client.c
usr.bin/tmux/tmux.h
usr.bin/tmux/window.c