diff options
| author | Aryadev Chavali <aryadev@aryadevchavali.com> | 2020-09-29 14:03:38 +0100 | 
|---|---|---|
| committer | Aryadev Chavali <aryadev@aryadevchavali.com> | 2020-09-29 14:03:38 +0100 | 
| commit | 5e7e634bdca71efd6f1b80e41bbe79170f4e24fc (patch) | |
| tree | 48ace3dc7e8fcd7fb9ea02de8f03d10f76e581b2 /dwm.c | |
| parent | acccf4fa7c1fec9be9299db9d4b525ba93cacd35 (diff) | |
| download | dwm-5e7e634bdca71efd6f1b80e41bbe79170f4e24fc.tar.gz dwm-5e7e634bdca71efd6f1b80e41bbe79170f4e24fc.tar.bz2 dwm-5e7e634bdca71efd6f1b80e41bbe79170f4e24fc.zip | |
+dwm attachaside and dwm pertag
Diffstat (limited to 'dwm.c')
| -rw-r--r-- | dwm.c | 122 | 
1 files changed, 111 insertions, 11 deletions
| @@ -49,7 +49,8 @@  #define CLEANMASK(mask)         (mask & ~(numlockmask|LockMask) & (ShiftMask|ControlMask|Mod1Mask|Mod2Mask|Mod3Mask|Mod4Mask|Mod5Mask))  #define INTERSECT(x,y,w,h,m)    (MAX(0, MIN((x)+(w),(m)->wx+(m)->ww) - MAX((x),(m)->wx)) \                                 * MAX(0, MIN((y)+(h),(m)->wy+(m)->wh) - MAX((y),(m)->wy))) -#define ISVISIBLE(C)            ((C->tags & C->mon->tagset[C->mon->seltags])) +#define ISVISIBLEONTAG(C, T)    ((C->tags & T)) +#define ISVISIBLE(C)            ISVISIBLEONTAG(C, C->mon->tagset[C->mon->seltags])  #define LENGTH(X)               (sizeof X / sizeof X[0])  #define MOUSEMASK               (BUTTONMASK|PointerMotionMask)  #define WIDTH(X)                ((X)->w + 2 * (X)->bw) @@ -111,6 +112,7 @@ typedef struct {  	void (*arrange)(Monitor *);  } Layout; +typedef struct Pertag Pertag;  struct Monitor {  	char ltsymbol[16];  	float mfact; @@ -131,6 +133,7 @@ struct Monitor {  	Monitor *next;  	Window barwin;  	const Layout *lt[2]; +	Pertag *pertag;  };  typedef struct { @@ -148,6 +151,7 @@ static int applysizehints(Client *c, int *x, int *y, int *w, int *h, int interac  static void arrange(Monitor *m);  static void arrangemon(Monitor *m);  static void attach(Client *c); +static void attachaside(Client *c);  static void attachstack(Client *c);  static void buttonpress(XEvent *e);  static void checkotherwm(void); @@ -186,6 +190,7 @@ static void maprequest(XEvent *e);  static void monocle(Monitor *m);  static void motionnotify(XEvent *e);  static void movemouse(const Arg *arg); +static Client *nexttagged(Client *c);  static Client *nexttiled(Client *c);  static void pop(Client *);  static void propertynotify(XEvent *e); @@ -278,7 +283,16 @@ static Window root, wmcheckwin;  /* configuration, allows nested code to access above variables */  #include "config.h" +struct Pertag { +	unsigned int curtag, prevtag; /* current and previous tag */ +	int nmasters[LENGTH(tags) + 1]; /* number of windows in master area */ +	float mfacts[LENGTH(tags) + 1]; /* mfacts per tag */ +	unsigned int sellts[LENGTH(tags) + 1]; /* selected layouts */ +	const Layout *ltidxs[LENGTH(tags) + 1][2]; /* matrix of tags and layouts indexes  */ +	int showbars[LENGTH(tags) + 1]; /* display bar for the current tag */ +}; +   static unsigned int scratchtag = 1 << LENGTH(tags);  /* compile-time check if all tags fit into an unsigned int bit array. */ @@ -417,6 +431,17 @@ attach(Client *c)  }  void +attachaside(Client *c) { +	Client *at = nexttagged(c); +	if(!at) { +		attach(c); +		return; + 	} +	c->next = at->next; +	at->next = c; +} + +void  attachstack(Client *c)  {  	c->snext = c->mon->stack; @@ -677,6 +702,7 @@ Monitor *  createmon(void)  {  	Monitor *m; +	unsigned int i;  	m = ecalloc(1, sizeof(Monitor));  	m->tagset[0] = m->tagset[1] = 1; @@ -688,6 +714,20 @@ createmon(void)  	m->lt[0] = &layouts[0];  	m->lt[1] = &layouts[1 % LENGTH(layouts)];  	strncpy(m->ltsymbol, layouts[0].symbol, sizeof m->ltsymbol); +	m->pertag = ecalloc(1, sizeof(Pertag)); +	m->pertag->curtag = m->pertag->prevtag = 1; + +	for (i = 0; i <= LENGTH(tags); i++) { +		m->pertag->nmasters[i] = m->nmaster; +		m->pertag->mfacts[i] = m->mfact; + +		m->pertag->ltidxs[i][0] = m->lt[0]; +		m->pertag->ltidxs[i][1] = m->lt[1]; +		m->pertag->sellts[i] = m->sellt; + +		m->pertag->showbars[i] = m->showbar; +	} +  	return m;  } @@ -1016,7 +1056,7 @@ grabkeys(void)  void  incnmaster(const Arg *arg)  { -	selmon->nmaster = MAX(selmon->nmaster + arg->i, 0); +	selmon->nmaster = selmon->pertag->nmasters[selmon->pertag->curtag] = MAX(selmon->nmaster + arg->i, 0);  	arrange(selmon);  } @@ -1120,10 +1160,10 @@ manage(Window w, XWindowAttributes *wa)  		c->isfloating = c->oldstate = trans != None || c->isfixed;  	if (c->isfloating)  		XRaiseWindow(dpy, c->win); -	attach(c); +	attachaside(c);  	attachstack(c);  	XChangeProperty(dpy, root, netatom[NetClientList], XA_WINDOW, 32, PropModeAppend, -		(unsigned char *) &(c->win), 1); +	                (unsigned char *) &(c->win), 1);  	XMoveResizeWindow(dpy, c->win, c->x + 2 * sw, c->y, c->w, c->h); /* some windows require this */  	setclientstate(c, NormalState);  	if (c->mon == selmon) @@ -1251,6 +1291,16 @@ movemouse(const Arg *arg)  }  Client * +nexttagged(Client *c) { +	Client *walked = c->mon->clients; +	for(; +		walked && (walked->isfloating || !ISVISIBLEONTAG(walked, c->tags)); +		walked = walked->next +	); +	return walked; +} + +Client *  nexttiled(Client *c)  {  	for (; c && (c->isfloating || !ISVISIBLE(c)); c = c->next); @@ -1475,7 +1525,7 @@ sendmon(Client *c, Monitor *m)  	detachstack(c);  	c->mon = m;  	c->tags = m->tagset[m->seltags]; /* assign tags of target monitor */ -	attach(c); +	attachaside(c);  	attachstack(c);  	focus(NULL);  	arrange(NULL); @@ -1569,9 +1619,9 @@ void  setlayout(const Arg *arg)  {  	if (!arg || !arg->v || arg->v != selmon->lt[selmon->sellt]) -		selmon->sellt ^= 1; +		selmon->sellt = selmon->pertag->sellts[selmon->pertag->curtag] ^= 1;  	if (arg && arg->v) -		selmon->lt[selmon->sellt] = (Layout *)arg->v; +		selmon->lt[selmon->sellt] = selmon->pertag->ltidxs[selmon->pertag->curtag][selmon->sellt] = (Layout *)arg->v;  	strncpy(selmon->ltsymbol, selmon->lt[selmon->sellt]->symbol, sizeof selmon->ltsymbol);  	if (selmon->sel)  		arrange(selmon); @@ -1590,7 +1640,7 @@ setmfact(const Arg *arg)  	f = arg->f < 1.0 ? arg->f + selmon->mfact : arg->f - 1.0;  	if (f < 0.05 || f > 0.95)  		return; -	selmon->mfact = f; +	selmon->mfact = selmon->pertag->mfacts[selmon->pertag->curtag] = f;  	arrange(selmon);  } @@ -1773,7 +1823,7 @@ tile(Monitor *m)  void  togglebar(const Arg *arg)  { -	selmon->showbar = !selmon->showbar; +	selmon->showbar = selmon->pertag->showbars[selmon->pertag->curtag] = !selmon->showbar;  	updatebarpos(selmon);  	XMoveResizeWindow(dpy, selmon->barwin, selmon->wx, selmon->by, selmon->ww, bh);  	arrange(selmon); @@ -1834,9 +1884,33 @@ void  toggleview(const Arg *arg)  {  	unsigned int newtagset = selmon->tagset[selmon->seltags] ^ (arg->ui & TAGMASK); +	int i;  	if (newtagset) {  		selmon->tagset[selmon->seltags] = newtagset; + +		if (newtagset == ~0) { +			selmon->pertag->prevtag = selmon->pertag->curtag; +			selmon->pertag->curtag = 0; +		} + +		/* test if the user did not select the same tag */ +		if (!(newtagset & 1 << (selmon->pertag->curtag - 1))) { +			selmon->pertag->prevtag = selmon->pertag->curtag; +			for (i = 0; !(newtagset & 1 << i); i++) ; +			selmon->pertag->curtag = i + 1; +		} + +		/* apply settings for this view */ +		selmon->nmaster = selmon->pertag->nmasters[selmon->pertag->curtag]; +		selmon->mfact = selmon->pertag->mfacts[selmon->pertag->curtag]; +		selmon->sellt = selmon->pertag->sellts[selmon->pertag->curtag]; +		selmon->lt[selmon->sellt] = selmon->pertag->ltidxs[selmon->pertag->curtag][selmon->sellt]; +		selmon->lt[selmon->sellt^1] = selmon->pertag->ltidxs[selmon->pertag->curtag][selmon->sellt^1]; + +		if (selmon->showbar != selmon->pertag->showbars[selmon->pertag->curtag]) +			togglebar(NULL); +  		focus(NULL);  		arrange(selmon);  	} @@ -1993,7 +2067,7 @@ updategeom(void)  					m->clients = c->next;  					detachstack(c);  					c->mon = mons; -					attach(c); +					attachaside(c);  					attachstack(c);  				}  				if (m == selmon) @@ -2133,11 +2207,37 @@ updatewmhints(Client *c)  void  view(const Arg *arg)  { +	int i; +	unsigned int tmptag; +  	if ((arg->ui & TAGMASK) == selmon->tagset[selmon->seltags])  		return;  	selmon->seltags ^= 1; /* toggle sel tagset */ -	if (arg->ui & TAGMASK) +	if (arg->ui & TAGMASK) {  		selmon->tagset[selmon->seltags] = arg->ui & TAGMASK; +		selmon->pertag->prevtag = selmon->pertag->curtag; + +		if (arg->ui == ~0) +			selmon->pertag->curtag = 0; +		else { +			for (i = 0; !(arg->ui & 1 << i); i++) ; +			selmon->pertag->curtag = i + 1; +		} +	} else { +		tmptag = selmon->pertag->prevtag; +		selmon->pertag->prevtag = selmon->pertag->curtag; +		selmon->pertag->curtag = tmptag; +	} + +	selmon->nmaster = selmon->pertag->nmasters[selmon->pertag->curtag]; +	selmon->mfact = selmon->pertag->mfacts[selmon->pertag->curtag]; +	selmon->sellt = selmon->pertag->sellts[selmon->pertag->curtag]; +	selmon->lt[selmon->sellt] = selmon->pertag->ltidxs[selmon->pertag->curtag][selmon->sellt]; +	selmon->lt[selmon->sellt^1] = selmon->pertag->ltidxs[selmon->pertag->curtag][selmon->sellt^1]; + +	if (selmon->showbar != selmon->pertag->showbars[selmon->pertag->curtag]) +		togglebar(NULL); +  	focus(NULL);  	arrange(selmon);  } | 
