From fcff044c2ca026b03fa969833a7eb16b3a41df02 Mon Sep 17 00:00:00 2001
From: Joe <bousset.rudy@gmail.com>
Date: Fri, 12 Aug 2022 15:21:36 +0200
Subject: update

---
 applied/dwm-6.2-taggrid.diff    | 253 ++++++++++++++++++++++++++++++++++++++++
 applied/dwm-bar-height-6.2.diff |  25 ++++
 applied/dwm-noborder-6.2.diff   |  30 -----
 3 files changed, 278 insertions(+), 30 deletions(-)
 create mode 100644 applied/dwm-6.2-taggrid.diff
 create mode 100644 applied/dwm-bar-height-6.2.diff
 delete mode 100644 applied/dwm-noborder-6.2.diff

(limited to 'applied')

diff --git a/applied/dwm-6.2-taggrid.diff b/applied/dwm-6.2-taggrid.diff
new file mode 100644
index 0000000..f5ed115
--- /dev/null
+++ b/applied/dwm-6.2-taggrid.diff
@@ -0,0 +1,253 @@
+diff --git a/config.def.h b/config.def.h
+index 1c0b587..2f8f34b 100644
+--- a/config.def.h
++++ b/config.def.h
+@@ -21,6 +21,22 @@ static const char *colors[][3]      = {
+ /* tagging */
+ static const char *tags[] = { "1", "2", "3", "4", "5", "6", "7", "8", "9" };
+ 
++/* grid of tags */
++#define DRAWCLASSICTAGS             1 << 0
++#define DRAWTAGGRID                 1 << 1
++
++#define SWITCHTAG_UP                1 << 0
++#define SWITCHTAG_DOWN              1 << 1
++#define SWITCHTAG_LEFT              1 << 2
++#define SWITCHTAG_RIGHT             1 << 3
++#define SWITCHTAG_TOGGLETAG         1 << 4
++#define SWITCHTAG_TAG               1 << 5
++#define SWITCHTAG_VIEW              1 << 6
++#define SWITCHTAG_TOGGLEVIEW        1 << 7
++
++static const unsigned int drawtagmask = DRAWTAGGRID; /* | DRAWCLASSICTAGS to show classic row of tags */
++static const int tagrows = 2;
++
+ static const Rule rules[] = {
+ 	/* xprop(1):
+ 	 *	WM_CLASS(STRING) = instance, class
+@@ -94,6 +110,16 @@ static Key keys[] = {
+ 	TAGKEYS(                        XK_8,                      7)
+ 	TAGKEYS(                        XK_9,                      8)
+ 	{ MODKEY|ShiftMask,             XK_q,      quit,           {0} },
++
++    { MODKEY|ControlMask,           XK_Up,     switchtag,      { .ui = SWITCHTAG_UP     | SWITCHTAG_VIEW } },
++    { MODKEY|ControlMask,           XK_Down,   switchtag,      { .ui = SWITCHTAG_DOWN   | SWITCHTAG_VIEW } },
++    { MODKEY|ControlMask,           XK_Right,  switchtag,      { .ui = SWITCHTAG_RIGHT  | SWITCHTAG_VIEW } },
++    { MODKEY|ControlMask,           XK_Left,   switchtag,      { .ui = SWITCHTAG_LEFT   | SWITCHTAG_VIEW } },
++
++    { MODKEY|Mod4Mask,              XK_Up,     switchtag,      { .ui = SWITCHTAG_UP     | SWITCHTAG_TAG | SWITCHTAG_VIEW } },
++    { MODKEY|Mod4Mask,              XK_Down,   switchtag,      { .ui = SWITCHTAG_DOWN   | SWITCHTAG_TAG | SWITCHTAG_VIEW } },
++    { MODKEY|Mod4Mask,              XK_Right,  switchtag,      { .ui = SWITCHTAG_RIGHT  | SWITCHTAG_TAG | SWITCHTAG_VIEW } },
++    { MODKEY|Mod4Mask,              XK_Left,   switchtag,      { .ui = SWITCHTAG_LEFT   | SWITCHTAG_TAG | SWITCHTAG_VIEW } },
+ };
+ 
+ /* button definitions */
+diff --git a/dwm.c b/dwm.c
+index 4465af1..5c29232 100644
+--- a/dwm.c
++++ b/dwm.c
+@@ -163,6 +163,7 @@ static void detachstack(Client *c);
+ static Monitor *dirtomon(int dir);
+ static void drawbar(Monitor *m);
+ static void drawbars(void);
++static void drawtaggrid(Monitor *m, int *x_pos, unsigned int occ);
+ static void enternotify(XEvent *e);
+ static void expose(XEvent *e);
+ static void focus(Client *c);
+@@ -206,6 +207,7 @@ static void seturgent(Client *c, int urg);
+ static void showhide(Client *c);
+ static void sigchld(int unused);
+ static void spawn(const Arg *arg);
++static void switchtag(const Arg *arg);
+ static void tag(const Arg *arg);
+ static void tagmon(const Arg *arg);
+ static void tile(Monitor *);
+@@ -417,11 +419,13 @@ void
+ buttonpress(XEvent *e)
+ {
+ 	unsigned int i, x, click;
++	unsigned int columns;
+ 	Arg arg = {0};
+ 	Client *c;
+ 	Monitor *m;
+ 	XButtonPressedEvent *ev = &e->xbutton;
+ 
++	columns = LENGTH(tags) / tagrows + ((LENGTH(tags) % tagrows > 0) ? 1 : 0);
+ 	click = ClkRootWin;
+ 	/* focus monitor if necessary */
+ 	if ((m = wintomon(ev->window)) && m != selmon) {
+@@ -431,13 +435,23 @@ buttonpress(XEvent *e)
+ 	}
+ 	if (ev->window == selmon->barwin) {
+ 		i = x = 0;
++		if (drawtagmask & DRAWCLASSICTAGS)
+ 		do
+ 			x += TEXTW(tags[i]);
+ 		while (ev->x >= x && ++i < LENGTH(tags));
+-		if (i < LENGTH(tags)) {
++		if(i < LENGTH(tags) && (drawtagmask & DRAWCLASSICTAGS)) {
+ 			click = ClkTagBar;
+ 			arg.ui = 1 << i;
+-		} else if (ev->x < x + blw)
++		} else if(ev->x < x + columns * bh / tagrows && (drawtagmask & DRAWTAGGRID)) {
++			click = ClkTagBar;
++			i = (ev->x - x) / (bh / tagrows);
++			i = i + columns * (ev->y / (bh / tagrows));
++			if (i >= LENGTH(tags)) {
++				i = LENGTH(tags) - 1;
++			}
++			arg.ui = 1 << i;
++		}
++		else if(ev->x < x + blw + columns * bh / tagrows)
+ 			click = ClkLtSymbol;
+ 		else if (ev->x > selmon->ww - TEXTW(stext))
+ 			click = ClkStatusText;
+@@ -714,6 +728,7 @@ drawbar(Monitor *m)
+ 			urg |= c->tags;
+ 	}
+ 	x = 0;
++	if (drawtagmask & DRAWCLASSICTAGS)
+ 	for (i = 0; i < LENGTH(tags); i++) {
+ 		w = TEXTW(tags[i]);
+ 		drw_setscheme(drw, scheme[m->tagset[m->seltags] & 1 << i ? SchemeSel : SchemeNorm]);
+@@ -724,6 +739,9 @@ drawbar(Monitor *m)
+ 				urg & 1 << i);
+ 		x += w;
+ 	}
++	if (drawtagmask & DRAWTAGGRID) {
++		drawtaggrid(m,&x,occ);
++	}
+ 	w = blw = TEXTW(m->ltsymbol);
+ 	drw_setscheme(drw, scheme[SchemeNorm]);
+ 	x = drw_text(drw, x, 0, w, bh, lrpad / 2, m->ltsymbol, 0);
+@@ -750,6 +768,48 @@ drawbars(void)
+ 	for (m = mons; m; m = m->next)
+ 		drawbar(m);
+ }
++void drawtaggrid(Monitor *m, int *x_pos, unsigned int occ)
++{
++    unsigned int x, y, h, max_x, columns;
++    int invert, i,j, k;
++
++    h = bh / tagrows;
++    x = max_x = *x_pos;
++    y = 0;
++    columns = LENGTH(tags) / tagrows + ((LENGTH(tags) % tagrows > 0) ? 1 : 0);
++
++    /* Firstly we will fill the borders of squares */
++
++    XSetForeground(drw->dpy, drw->gc, scheme[SchemeNorm][ColBorder].pixel);
++    XFillRectangle(dpy, drw->drawable, drw->gc, x, y, h*columns + 1, bh);
++
++    /* We will draw LENGTH(tags) squares in tagraws raws. */
++	for(j = 0,  i= 0; j < tagrows; j++) {
++        x = *x_pos;
++        for (k = 0; k < columns && i < LENGTH(tags); k++, i++) {
++		    invert = m->tagset[m->seltags] & 1 << i ? 0 : 1;
++
++            /* Select active color for current square */
++            XSetForeground(drw->dpy, drw->gc, !invert ? scheme[SchemeSel][ColBg].pixel :
++                                scheme[SchemeNorm][ColFg].pixel);
++            XFillRectangle(dpy, drw->drawable, drw->gc, x+1, y+1, h-1, h-1);
++
++            /* Mark square if tag has client */
++            if (occ & 1 << i) {
++                XSetForeground(drw->dpy, drw->gc, !invert ? scheme[SchemeSel][ColFg].pixel :
++                                scheme[SchemeNorm][ColBg].pixel);
++                XFillRectangle(dpy, drw->drawable, drw->gc, x + 1, y + 1,
++                               h / 2, h / 2);
++            }
++		    x += h;
++            if (x > max_x) {
++                max_x = x;
++            }
++        }
++        y += h;
++	}
++    *x_pos = max_x + 1;
++}
+ 
+ void
+ enternotify(XEvent *e)
+@@ -1627,6 +1687,81 @@ showhide(Client *c)
+ 		XMoveWindow(dpy, c->win, WIDTH(c) * -2, c->y);
+ 	}
+ }
++void switchtag(const Arg *arg)
++{
++    unsigned int columns;
++    unsigned int new_tagset = 0;
++    unsigned int pos, i;
++    int col, row;
++    Arg new_arg;
++
++    columns = LENGTH(tags) / tagrows + ((LENGTH(tags) % tagrows > 0) ? 1 : 0);
++
++    for (i = 0; i < LENGTH(tags); ++i) {
++        if (!(selmon->tagset[selmon->seltags] & 1 << i)) {
++            continue;
++        }
++        pos = i;
++        row = pos / columns;
++        col = pos % columns;
++        if (arg->ui & SWITCHTAG_UP) {     /* UP */
++            row --;
++            if (row < 0) {
++                row = tagrows - 1;
++            }
++            do {
++                pos = row * columns + col;
++                row --;
++            } while (pos >= LENGTH(tags));
++        }
++        if (arg->ui & SWITCHTAG_DOWN) {     /* DOWN */
++            row ++;
++            if (row >= tagrows) {
++                row = 0;
++            }
++            pos = row * columns + col;
++            if (pos >= LENGTH(tags)) {
++                row = 0;
++            }
++            pos = row * columns + col;
++        }
++        if (arg->ui & SWITCHTAG_LEFT) {     /* LEFT */
++            col --;
++            if (col < 0) {
++                col = columns - 1;
++            }
++            do {
++                pos = row * columns + col;
++                col --;
++            } while (pos >= LENGTH(tags));
++        }
++        if (arg->ui & SWITCHTAG_RIGHT) {     /* RIGHT */
++            col ++;
++            if (col >= columns) {
++                col = 0;
++            }
++            pos = row * columns + col;
++            if (pos >= LENGTH(tags)) {
++                col = 0;
++                pos = row * columns + col;
++            }
++        }
++        new_tagset |= 1 << pos;
++    }
++    new_arg.ui = new_tagset;
++    if (arg->ui & SWITCHTAG_TOGGLETAG) {
++        toggletag(&new_arg);
++    }
++    if (arg->ui & SWITCHTAG_TAG) {
++        tag(&new_arg);
++    }
++    if (arg->ui & SWITCHTAG_VIEW) {
++        view (&new_arg);
++    }
++    if (arg->ui & SWITCHTAG_TOGGLEVIEW) {
++        toggleview (&new_arg);
++    }
++}
+ 
+ void
+ sigchld(int unused)
diff --git a/applied/dwm-bar-height-6.2.diff b/applied/dwm-bar-height-6.2.diff
new file mode 100644
index 0000000..a576111
--- /dev/null
+++ b/applied/dwm-bar-height-6.2.diff
@@ -0,0 +1,25 @@
+diff --git a/config.def.h b/config.def.h
+index 1c0b587..9814500 100644
+--- a/config.def.h
++++ b/config.def.h
+@@ -5,6 +5,7 @@ static const unsigned int borderpx  = 1;        /* border pixel of windows */
+ static const unsigned int snap      = 32;       /* snap pixel */
+ static const int showbar            = 1;        /* 0 means no bar */
+ static const int topbar             = 1;        /* 0 means bottom bar */
++static const int user_bh            = 0;        /* 0 means that dwm will calculate bar height, >= 1 means dwm will user_bh as bar height */
+ static const char *fonts[]          = { "monospace:size=10" };
+ static const char dmenufont[]       = "monospace:size=10";
+ static const char col_gray1[]       = "#222222";
+diff --git a/dwm.c b/dwm.c
+index 4465af1..2c27cb3 100644
+--- a/dwm.c
++++ b/dwm.c
+@@ -1545,7 +1545,7 @@ setup(void)
+ 	if (!drw_fontset_create(drw, fonts, LENGTH(fonts)))
+ 		die("no fonts could be loaded.");
+ 	lrpad = drw->fonts->h;
+-	bh = drw->fonts->h + 2;
++	bh = user_bh ? user_bh : drw->fonts->h + 2;
+ 	updategeom();
+ 	/* init atoms */
+ 	utf8string = XInternAtom(dpy, "UTF8_STRING", False);
diff --git a/applied/dwm-noborder-6.2.diff b/applied/dwm-noborder-6.2.diff
deleted file mode 100644
index f381eb8..0000000
--- a/applied/dwm-noborder-6.2.diff
+++ /dev/null
@@ -1,30 +0,0 @@
-From 9102fdb9c670218373bbe83c891c8e8138d6a6f4 Mon Sep 17 00:00:00 2001
-From: redacted <redacted@example.com>
-Date: Tue, 23 Apr 2019 00:39:27 +0100
-Subject: [PATCH] added noborder patch
-
----
- dwm.c | 7 +++++++
- 1 file changed, 7 insertions(+)
-
-diff --git a/dwm.c b/dwm.c
-index 4465af1..685eca1 100644
---- a/dwm.c
-+++ b/dwm.c
-@@ -1282,6 +1282,13 @@ resizeclient(Client *c, int x, int y, int w, int h)
- 	c->oldw = c->w; c->w = wc.width = w;
- 	c->oldh = c->h; c->h = wc.height = h;
- 	wc.border_width = c->bw;
-+	if (((nexttiled(c->mon->clients) == c && !nexttiled(c->next))
-+	    || &monocle == c->mon->lt[c->mon->sellt]->arrange)
-+	    && !c->isfullscreen && !c->isfloating) {
-+		c->w = wc.width += c->bw * 2;
-+		c->h = wc.height += c->bw * 2;
-+		wc.border_width = 0;
-+	}
- 	XConfigureWindow(dpy, c->win, CWX|CWY|CWWidth|CWHeight|CWBorderWidth, &wc);
- 	configure(c);
- 	XSync(dpy, False);
--- 
-2.21.0
-
-- 
cgit v1.2.3