diff options
Diffstat (limited to '')
| -rw-r--r-- | config.def.h | 2 | ||||
| -rw-r--r-- | dwm.c | 27 | 
2 files changed, 29 insertions, 0 deletions
| diff --git a/config.def.h b/config.def.h index 62319e2..63d328a 100644 --- a/config.def.h +++ b/config.def.h @@ -50,6 +50,7 @@ static const Layout layouts[] = {  	{ "><>",      NULL },    /* no layout function means floating behavior */  	{ "[M]",      monocle },  	{ "|M|",      centeredmaster }, +	{ "||=",      col },  };  /* key definitions */ @@ -98,6 +99,7 @@ static const Key keys[] = {  	{ MODKEY,                       XK_f,      setlayout,      {.v = &layouts[1]} },  	{ MODKEY,                       XK_m,      setlayout,      {.v = &layouts[2]} },  	{ MODKEY,                       XK_u,      setlayout,      {.v = &layouts[3]} }, +	{ MODKEY,                       XK_o,      setlayout,      {.v = &layouts[4]} },  	{ MODKEY,                       XK_comma,  focusmon,       {.i = -1 } },  	{ MODKEY,                       XK_period, focusmon,       {.i = +1 } },  	{ MODKEY|ShiftMask,             XK_comma,  tagmon,         {.i = -1 } }, @@ -157,6 +157,7 @@ static void checkotherwm(void);  static void cleanup(void);  static void cleanupmon(Monitor *mon);  static void clientmessage(XEvent *e); +static void col(Monitor *);  static void configure(Client *c);  static void configurenotify(XEvent *e);  static void configurerequest(XEvent *e); @@ -1763,6 +1764,32 @@ tagmon(const Arg *arg)  }  void +col(Monitor *m) +{ +	unsigned int i, n, h, w, x, y, mw; +	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 * m->mfact : 0; +	else +		mw = m->ww; +	for (i = x = y = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), i++) +		if (i < m->nmaster) { +			w = (mw - x) / (MIN(n, m->nmaster) - i); +			resize(c, x + m->wx, m->wy, w - (2 * c->bw), m->wh - (2 * c->bw), 0); +			x += WIDTH(c); +		} else { +			h = (m->wh - y) / (n - i); +			resize(c, x + m->wx, m->wy + y, m->ww - x - (2 * c->bw), h - (2 * c->bw), 0); +			y += HEIGHT(c); +		} +} + +void  tile(Monitor *m)  {  	unsigned int i, n, h, mw, my, ty; | 
