summaryrefslogtreecommitdiffstats
path: root/resize.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@openbsd.org>2009-07-14 07:23:36 +0000
committerNicholas Marriott <nicm@openbsd.org>2009-07-14 07:23:36 +0000
commitfe20c0d89ef5b8581c28067496f0f4c545d55ef8 (patch)
treee3283e2030d865de1025215bb8527636c78966b8 /resize.c
parent4a9b01eb0d328f13a03f967759bfd76d749da17f (diff)
Get rid of the PANE_HIDDEN flag in favour of a function, and moving the
decision for whether or not a pane should be drawn out of the layout code and into the redraw code. This is needed for the new layout design, getting it in now to make that easier to work on.
Diffstat (limited to 'resize.c')
-rw-r--r--resize.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/resize.c b/resize.c
index 50e12fb0..1c2377f5 100644
--- a/resize.c
+++ b/resize.c
@@ -48,6 +48,7 @@ recalculate_sizes(void)
struct session *s;
struct client *c;
struct window *w;
+ struct window_pane *wp;
u_int i, j, ssx, ssy, has, limit;
int flag;
@@ -132,6 +133,20 @@ recalculate_sizes(void)
"window size %u,%u (was %u,%u)", ssx, ssy, w->sx, w->sy);
window_resize(w, ssx, ssy);
+
+ /*
+ * If the current pane is now not visible, move to the next
+ * that is.
+ */
+ wp = w->active;
+ while (!window_pane_visible(w->active)) {
+ w->active = TAILQ_PREV(w->active, window_panes, entry);
+ if (w->active == NULL)
+ w->active = TAILQ_LAST(&w->panes, window_panes);
+ if (w->active == wp)
+ break;
+ }
+
server_redraw_window(w);
layout_refresh(w, 0);
}