diff options
author | Thomas Adam <thomas@xteddy.org> | 2017-11-15 22:01:22 +0000 |
---|---|---|
committer | Thomas Adam <thomas@xteddy.org> | 2017-11-15 22:01:22 +0000 |
commit | 102df8dc8047d992e2fe72a2aa3d2f7eee3d185a (patch) | |
tree | 09024ef81f7bfb23ca511424767cf33e742abbbe /layout.c | |
parent | e58d16b2df52beefd5094ac61bb9e44c123df3e7 (diff) | |
parent | 3b649d2fcdc8a15c69efbce69ae9e559481d36cb (diff) | |
download | rtmux-102df8dc8047d992e2fe72a2aa3d2f7eee3d185a.tar.gz rtmux-102df8dc8047d992e2fe72a2aa3d2f7eee3d185a.tar.bz2 rtmux-102df8dc8047d992e2fe72a2aa3d2f7eee3d185a.zip |
Merge branch 'obsd-master'
Diffstat (limited to 'layout.c')
-rw-r--r-- | layout.c | 58 |
1 files changed, 58 insertions, 0 deletions
@@ -983,3 +983,61 @@ layout_close_pane(struct window_pane *wp) } notify_window("window-layout-changed", w); } + +int +layout_spread_cell(struct window *w, struct layout_cell *parent) +{ + struct layout_cell *lc; + u_int number, each, size; + int change, changed; + + number = 0; + TAILQ_FOREACH (lc, &parent->cells, entry) + number++; + if (number <= 1) + return (0); + + if (parent->type == LAYOUT_LEFTRIGHT) + size = parent->sx; + else if (parent->type == LAYOUT_TOPBOTTOM) + size = parent->sy; + else + return (0); + each = (size - (number - 1)) / number; + + changed = 0; + TAILQ_FOREACH (lc, &parent->cells, entry) { + if (TAILQ_NEXT(lc, entry) == NULL) + each = size - (each * (number - 1)); + change = 0; + if (parent->type == LAYOUT_LEFTRIGHT) { + change = each - (int)lc->sx; + layout_resize_adjust(w, lc, LAYOUT_LEFTRIGHT, change); + } else if (parent->type == LAYOUT_TOPBOTTOM) { + change = each - (int)lc->sy; + layout_resize_adjust(w, lc, LAYOUT_TOPBOTTOM, change); + } + if (change != 0) + changed = 1; + } + return (changed); +} + +void +layout_spread_out(struct window_pane *wp) +{ + struct layout_cell *parent; + struct window *w = wp->window; + + parent = wp->layout_cell->parent; + if (parent == NULL) + return; + + do { + if (layout_spread_cell(w, parent)) { + layout_fix_offsets(parent); + layout_fix_panes(w, w->sx, w->sy); + break; + } + } while ((parent = parent->parent) != NULL); +} |