summaryrefslogtreecommitdiffstats
path: root/dwm.c
diff options
context:
space:
mode:
Diffstat (limited to 'dwm.c')
-rw-r--r--dwm.c34
1 files changed, 34 insertions, 0 deletions
diff --git a/dwm.c b/dwm.c
index 1114e78..33f83cf 100644
--- a/dwm.c
+++ b/dwm.c
@@ -168,6 +168,7 @@ static void detachstack(Client *c);
static Monitor *dirtomon(int dir);
static void drawbar(Monitor *m);
static void drawbars(void);
+static void elit(Monitor *m);
static void enternotify(XEvent *e);
static void expose(XEvent *e);
static void focus(Client *c);
@@ -835,6 +836,39 @@ drawbars(void)
}
void
+elit(Monitor *m)
+{
+ unsigned int i, n, h, mw, my, ty, nslave;
+ Client *c;
+
+ for (n = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), n++);
+ if (n == 0)
+ return;
+
+ if (n > m->nmaster) {
+ mw = m->nmaster ? m->ww * (1 - m->mfact) : 0;
+ nslave = n - m->nmaster;
+ } else {
+ mw = m->ww;
+ nslave = 0;
+ }
+
+ for (i = ty = my = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), i++) {
+ if (i < nslave) {
+ h = (m->wh - ty) / (nslave - i);
+ resize(c, m->wx, m->wy + ty, m->ww - mw - (2*c->bw), h - (2*c->bw), 0);
+ if (ty + HEIGHT(c) < m->wh)
+ ty += HEIGHT(c);
+ } else {
+ h = (m->wh - my) / (n - i);
+ resize(c, m->wx + (m->ww - mw), m->wy + my, mw - (2*c->bw), h - (2*c->bw), 0);
+ if (my + HEIGHT(c) < m->wh)
+ my += HEIGHT(c);
+ }
+ }
+}
+
+void
enternotify(XEvent *e)
{
Client *c;