archy-dwm/tile.c

88 lines
1.6 KiB
C
Raw Normal View History

/* See LICENSE file for copyright and license details. */
#include "dwm.h"
#include <stdio.h>
/* static */
static double mwfact = MWFACT;
/* extern */
void
2007-08-17 19:10:50 +00:00
setmwfact(const char *arg) {
double delta, newfact;
2007-08-13 17:22:51 +00:00
if(!isarrange(tile))
return;
/* arg handling, manipulate mwfact */
2007-08-16 06:05:30 +00:00
if(arg == NULL)
mwfact = MWFACT;
else if(1 == sscanf(arg, "%lf", &delta)) {
2007-08-17 19:10:50 +00:00
if(arg[0] != '+' && arg[0] != '-')
newfact = delta;
else
newfact = mwfact + delta;
if(newfact < 0.1)
newfact = 0.1;
else if(newfact > 0.9)
newfact = 0.9;
mwfact = newfact;
}
arrange();
}
void
tile(void) {
unsigned int i, n, nx, ny, nw, nh, mw, th;
Client *c;
for(n = 0, c = nexttiled(clients); c; c = nexttiled(c->next))
n++;
/* window geoms */
mw = (n == 1) ? waw : mwfact * waw;
th = (n > 1) ? wah / (n - 1) : 0;
if(n > 1 && th < bh)
th = wah;
nx = wax;
ny = way;
2007-08-13 17:19:38 +00:00
for(i = 0, c = nexttiled(clients); c; c = nexttiled(c->next)) {
c->ismax = False;
if(i == 0) { /* master */
nw = mw - 2 * c->border;
nh = wah - 2 * c->border;
}
else { /* tile window */
if(i == 1) {
ny = way;
nx += mw;
}
2007-08-13 17:19:38 +00:00
nw = waw - mw - 2 * c->border;
if(i + 1 == n) /* remainder */
nh = (way + wah) - ny - 2 * c->border;
else
nh = th - 2 * c->border;
}
2007-08-13 17:19:38 +00:00
resize(c, nx, ny, nw, nh, False);
if(n > 1 && th != wah)
ny += nh + 2 * c->border;
i++;
}
}
void
zoom(const char *arg) {
Client *c;
if(!sel || !isarrange(tile) || sel->isfloating)
return;
if((c = sel) == nexttiled(clients))
if(!(c = nexttiled(c->next)))
return;
detach(c);
attach(c);
focus(c);
arrange();
}