tile: evenly distribute slave clients over slave columns
Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
parent
8bafd24882
commit
df4748f775
|
@ -38,6 +38,7 @@ _tile(int screen, const position_t position)
|
||||||
unsigned int mw = 0, mh = 0;
|
unsigned int mw = 0, mh = 0;
|
||||||
int n, i, masterwin = 0, otherwin = 0;
|
int n, i, masterwin = 0, otherwin = 0;
|
||||||
int real_ncol = 1, win_by_col = 1, current_col = 0;
|
int real_ncol = 1, win_by_col = 1, current_col = 0;
|
||||||
|
int small_ncol, adj_win_by_col;
|
||||||
area_t area, geometry = { 0, 0, 0, 0 };
|
area_t area, geometry = { 0, 0, 0, 0 };
|
||||||
client_t *c;
|
client_t *c;
|
||||||
tag_t **curtags = tags_get_current(screen);
|
tag_t **curtags = tags_get_current(screen);
|
||||||
|
@ -114,30 +115,38 @@ _tile(int screen, const position_t position)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if(real_ncol)
|
win_by_col = otherwin / real_ncol;
|
||||||
win_by_col = otherwin / real_ncol;
|
small_ncol = (win_by_col + 1) * real_ncol - otherwin;
|
||||||
|
adj_win_by_col = current_col < small_ncol ? 0 : 1;
|
||||||
|
|
||||||
if((i - curtags[0]->nmaster)
|
if((i - curtags[0]->nmaster) &&
|
||||||
&& (i - curtags[0]->nmaster) % win_by_col == 0
|
(i - curtags[0]->nmaster + small_ncol * adj_win_by_col)
|
||||||
&& current_col < real_ncol - 1)
|
% (win_by_col + adj_win_by_col) == 0 &&
|
||||||
|
current_col < real_ncol - 1)
|
||||||
current_col++;
|
current_col++;
|
||||||
|
|
||||||
if(current_col == real_ncol - 1)
|
adj_win_by_col = current_col < small_ncol ? 0 : 1;
|
||||||
win_by_col += otherwin % real_ncol;
|
|
||||||
|
|
||||||
if(position == Right || position == Left)
|
if(position == Right || position == Left)
|
||||||
{
|
{
|
||||||
if(otherwin <= real_ncol)
|
if(otherwin <= real_ncol)
|
||||||
geometry.height = wah - 2 * c->border;
|
geometry.height = wah - 2 * c->border;
|
||||||
else
|
else
|
||||||
geometry.height = (wah / win_by_col) - 2 * c->border;
|
geometry.height = (wah / (win_by_col + adj_win_by_col)) -
|
||||||
|
2 * c->border;
|
||||||
|
|
||||||
geometry.width = (waw - mw) / real_ncol - 2 * c->border;
|
geometry.width = (waw - mw) / real_ncol - 2 * c->border;
|
||||||
|
|
||||||
if(i == curtags[0]->nmaster || otherwin <= real_ncol || (i - curtags[0]->nmaster) % win_by_col == 0)
|
if(otherwin <= real_ncol ||
|
||||||
|
(i - curtags[0]->nmaster + small_ncol * adj_win_by_col)
|
||||||
|
% (win_by_col + adj_win_by_col) == 0)
|
||||||
geometry.y = way;
|
geometry.y = way;
|
||||||
else
|
else
|
||||||
geometry.y = way + ((i - curtags[0]->nmaster) % win_by_col) * (geometry.height + 2 * c->border);
|
geometry.y = way +
|
||||||
|
((i - curtags[0]->nmaster +
|
||||||
|
small_ncol * adj_win_by_col) %
|
||||||
|
(win_by_col + adj_win_by_col)) *
|
||||||
|
(geometry.height + 2 * c->border);
|
||||||
|
|
||||||
geometry.x = wax + current_col * (geometry.width + 2 * c->border);
|
geometry.x = wax + current_col * (geometry.width + 2 * c->border);
|
||||||
|
|
||||||
|
@ -149,14 +158,21 @@ _tile(int screen, const position_t position)
|
||||||
if(otherwin <= real_ncol)
|
if(otherwin <= real_ncol)
|
||||||
geometry.width = waw - 2 * c->border;
|
geometry.width = waw - 2 * c->border;
|
||||||
else
|
else
|
||||||
geometry.width = (waw / win_by_col) - 2 * c->border;
|
geometry.width = (waw / (win_by_col + adj_win_by_col)) -
|
||||||
|
2 * c->border;
|
||||||
|
|
||||||
geometry.height = (wah - mh) / real_ncol - 2 * c->border;
|
geometry.height = (wah - mh) / real_ncol - 2 * c->border;
|
||||||
|
|
||||||
if(i == curtags[0]->nmaster || otherwin <= real_ncol || (i - curtags[0]->nmaster) % win_by_col == 0)
|
if(otherwin <= real_ncol ||
|
||||||
|
(i - curtags[0]->nmaster + small_ncol * adj_win_by_col)
|
||||||
|
% (win_by_col + adj_win_by_col) == 0)
|
||||||
geometry.x = wax;
|
geometry.x = wax;
|
||||||
else
|
else
|
||||||
geometry.x = wax + ((i - curtags[0]->nmaster) % win_by_col) * (geometry.width + 2 * c->border);
|
geometry.x = wax +
|
||||||
|
((i - curtags[0]->nmaster +
|
||||||
|
small_ncol * adj_win_by_col) %
|
||||||
|
(win_by_col + adj_win_by_col)) *
|
||||||
|
(geometry.width + 2 * c->border);
|
||||||
|
|
||||||
geometry.y = way + current_col * (geometry.height + 2 * c->border);
|
geometry.y = way + current_col * (geometry.height + 2 * c->border);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue