Merge branch 'patch-hideunusedtags' into dwm-patched
This commit is contained in:
		@@ -58,7 +58,7 @@ static const Layout layouts[] = {
 | 
				
			|||||||
/* commands */
 | 
					/* commands */
 | 
				
			||||||
static char dmenumon[2] = "0"; /* component of dmenucmd, manipulated in spawn() */
 | 
					static char dmenumon[2] = "0"; /* component of dmenucmd, manipulated in spawn() */
 | 
				
			||||||
static const char *dmenucmd[] = { "dmenu_run", "-m", dmenumon, "-fn", dmenufont, "-nb", col_gray1, "-nf", col_gray3, "-sb", col_cyan, "-sf", col_gray4, NULL };
 | 
					static const char *dmenucmd[] = { "dmenu_run", "-m", dmenumon, "-fn", dmenufont, "-nb", col_gray1, "-nf", col_gray3, "-sb", col_cyan, "-sf", col_gray4, NULL };
 | 
				
			||||||
static const char *termcmd[]  = { "st", NULL };
 | 
					static const char *termcmd[]  = { "alacritty", NULL };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include "movestack.c"
 | 
					#include "movestack.c"
 | 
				
			||||||
static Key keys[] = {
 | 
					static Key keys[] = {
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										39
									
								
								dwm-hide_vacant_tags-6.3.diff
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								dwm-hide_vacant_tags-6.3.diff
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,39 @@
 | 
				
			|||||||
 | 
					diff --git a/dwm.c b/dwm.c
 | 
				
			||||||
 | 
					index a96f33c..f2da729 100644
 | 
				
			||||||
 | 
					--- a/dwm.c
 | 
				
			||||||
 | 
					+++ b/dwm.c
 | 
				
			||||||
 | 
					@@ -432,9 +432,15 @@ buttonpress(XEvent *e)
 | 
				
			||||||
 | 
					 	}
 | 
				
			||||||
 | 
					 	if (ev->window == selmon->barwin) {
 | 
				
			||||||
 | 
					 		i = x = 0;
 | 
				
			||||||
 | 
					-		do
 | 
				
			||||||
 | 
					+		unsigned int occ = 0;
 | 
				
			||||||
 | 
					+		for(c = m->clients; c; c=c->next)
 | 
				
			||||||
 | 
					+			occ |= c->tags;
 | 
				
			||||||
 | 
					+		do {
 | 
				
			||||||
 | 
					+			/* Do not reserve space for vacant tags */
 | 
				
			||||||
 | 
					+			if (!(occ & 1 << i || m->tagset[m->seltags] & 1 << i))
 | 
				
			||||||
 | 
					+				continue;
 | 
				
			||||||
 | 
					 			x += TEXTW(tags[i]);
 | 
				
			||||||
 | 
					-		while (ev->x >= x && ++i < LENGTH(tags));
 | 
				
			||||||
 | 
					+		} while (ev->x >= x && ++i < LENGTH(tags));
 | 
				
			||||||
 | 
					 		if (i < LENGTH(tags)) {
 | 
				
			||||||
 | 
					 			click = ClkTagBar;
 | 
				
			||||||
 | 
					 			arg.ui = 1 << i;
 | 
				
			||||||
 | 
					@@ -719,13 +725,12 @@ drawbar(Monitor *m)
 | 
				
			||||||
 | 
					 	}
 | 
				
			||||||
 | 
					 	x = 0;
 | 
				
			||||||
 | 
					 	for (i = 0; i < LENGTH(tags); i++) {
 | 
				
			||||||
 | 
					+		/* Do not draw vacant tags */
 | 
				
			||||||
 | 
					+		if(!(occ & 1 << i || m->tagset[m->seltags] & 1 << i))
 | 
				
			||||||
 | 
					+			continue;
 | 
				
			||||||
 | 
					 		w = TEXTW(tags[i]);
 | 
				
			||||||
 | 
					 		drw_setscheme(drw, scheme[m->tagset[m->seltags] & 1 << i ? SchemeSel : SchemeNorm]);
 | 
				
			||||||
 | 
					 		drw_text(drw, x, 0, w, bh, lrpad / 2, tags[i], urg & 1 << i);
 | 
				
			||||||
 | 
					-		if (occ & 1 << i)
 | 
				
			||||||
 | 
					-			drw_rect(drw, x + boxs, boxs, boxw, boxw,
 | 
				
			||||||
 | 
					-				m == selmon && selmon->sel && selmon->sel->tags & 1 << i,
 | 
				
			||||||
 | 
					-				urg & 1 << i);
 | 
				
			||||||
 | 
					 		x += w;
 | 
				
			||||||
 | 
					 	}
 | 
				
			||||||
 | 
					 	w = blw = TEXTW(m->ltsymbol);
 | 
				
			||||||
							
								
								
									
										17
									
								
								dwm.c
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								dwm.c
									
									
									
									
									
								
							@@ -439,9 +439,15 @@ buttonpress(XEvent *e)
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
	if (ev->window == selmon->barwin) {
 | 
						if (ev->window == selmon->barwin) {
 | 
				
			||||||
		i = x = 0;
 | 
							i = x = 0;
 | 
				
			||||||
		do
 | 
							unsigned int occ = 0;
 | 
				
			||||||
 | 
							for(c = m->clients; c; c=c->next)
 | 
				
			||||||
 | 
								occ |= c->tags;
 | 
				
			||||||
 | 
							do {
 | 
				
			||||||
 | 
								/* Do not reserve space for vacant tags */
 | 
				
			||||||
 | 
								if (!(occ & 1 << i || m->tagset[m->seltags] & 1 << i))
 | 
				
			||||||
 | 
									continue;
 | 
				
			||||||
			x += TEXTW(tags[i]);
 | 
								x += TEXTW(tags[i]);
 | 
				
			||||||
		while (ev->x >= x && ++i < LENGTH(tags));
 | 
							} while (ev->x >= x && ++i < LENGTH(tags));
 | 
				
			||||||
		if (i < LENGTH(tags)) {
 | 
							if (i < LENGTH(tags)) {
 | 
				
			||||||
			click = ClkTagBar;
 | 
								click = ClkTagBar;
 | 
				
			||||||
			arg.ui = 1 << i;
 | 
								arg.ui = 1 << i;
 | 
				
			||||||
@@ -832,13 +838,12 @@ drawbar(Monitor *m)
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
	x = 0;
 | 
						x = 0;
 | 
				
			||||||
	for (i = 0; i < LENGTH(tags); i++) {
 | 
						for (i = 0; i < LENGTH(tags); i++) {
 | 
				
			||||||
 | 
							/* Do not draw vacant tags */
 | 
				
			||||||
 | 
							if(!(occ & 1 << i || m->tagset[m->seltags] & 1 << i))
 | 
				
			||||||
 | 
								continue;
 | 
				
			||||||
		w = TEXTW(tags[i]);
 | 
							w = TEXTW(tags[i]);
 | 
				
			||||||
		drw_setscheme(drw, scheme[m->tagset[m->seltags] & 1 << i ? SchemeSel : SchemeNorm]);
 | 
							drw_setscheme(drw, scheme[m->tagset[m->seltags] & 1 << i ? SchemeSel : SchemeNorm]);
 | 
				
			||||||
		drw_text(drw, x, 0, w, bh, lrpad / 2, tags[i], urg & 1 << i);
 | 
							drw_text(drw, x, 0, w, bh, lrpad / 2, tags[i], urg & 1 << i);
 | 
				
			||||||
		if (occ & 1 << i)
 | 
					 | 
				
			||||||
			drw_rect(drw, x + boxs, boxs, boxw, boxw,
 | 
					 | 
				
			||||||
				m == selmon && selmon->sel && selmon->sel->tags & 1 << i,
 | 
					 | 
				
			||||||
				urg & 1 << i);
 | 
					 | 
				
			||||||
		x += w;
 | 
							x += w;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	w = blw = TEXTW(m->ltsymbol);
 | 
						w = blw = TEXTW(m->ltsymbol);
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user