Compare commits

..

6 Commits

Author SHA1 Message Date
164ff48dd4 movestack patch 2024-05-24 20:29:54 -04:00
d00a5f3227 also reset nmaster w/ reset layout 2024-05-24 20:29:54 -04:00
1e391a31fd reset layout patch 2024-05-24 20:29:54 -04:00
Jakub
90da2ddac4 Replace "no border patch" with remove border patch
This reverts commit e6862bb55b.
2024-05-24 20:29:54 -04:00
Jakub
b0c010ec9a exit menu patch 2024-05-24 20:29:54 -04:00
f463bb987f Add launchers patch to bottom bar
- removed left extra status
- removed/renamed some l/r specific variables
2024-05-24 20:29:45 -04:00
2 changed files with 59 additions and 1 deletions

2
dwm.c
View File

@ -2848,7 +2848,7 @@ updatestatus(void)
*s = '\0'; s++; *s = '\0'; s++;
strncpy(estext, s, sizeof(estext) - 1); strncpy(estext, s, sizeof(estext) - 1);
} else } else
estext[0] = 'Christ is king'; estext[0] = '\0';
strncpy(stext, text, sizeof(stext) - 1); strncpy(stext, text, sizeof(stext) - 1);
} }
for(m = mons; m; m = m->next) for(m = mons; m; m = m->next)

View File

@ -0,0 +1,58 @@
diff --git a/config.def.h b/config.def.h
index 1c0b587..961a189 100644
--- a/config.def.h
+++ b/config.def.h
@@ -70,6 +70,7 @@ static Key keys[] = {
{ MODKEY, XK_d, incnmaster, {.i = -1 } },
{ MODKEY, XK_h, setmfact, {.f = -0.05} },
{ MODKEY, XK_l, setmfact, {.f = +0.05} },
+ { MODKEY, XK_r, reorganizetags, {0} },
{ MODKEY, XK_Return, zoom, {0} },
{ MODKEY, XK_Tab, view, {0} },
{ MODKEY|ShiftMask, XK_c, killclient, {0} },
diff --git a/dwm.c b/dwm.c
index 4465af1..723d675 100644
--- a/dwm.c
+++ b/dwm.c
@@ -188,6 +188,7 @@ static void pop(Client *);
static void propertynotify(XEvent *e);
static void quit(const Arg *arg);
static Monitor *recttomon(int x, int y, int w, int h);
+static void reorganizetags(const Arg *arg);
static void resize(Client *c, int x, int y, int w, int h, int interact);
static void resizeclient(Client *c, int x, int y, int w, int h);
static void resizemouse(const Arg *arg);
@@ -1265,6 +1266,33 @@ recttomon(int x, int y, int w, int h)
return r;
}
+void
+reorganizetags(const Arg *arg) {
+ Client *c;
+ unsigned int occ, unocc, i;
+ unsigned int tagdest[LENGTH(tags)];
+
+ occ = 0;
+ for (c = selmon->clients; c; c = c->next)
+ occ |= (1 << (ffs(c->tags)-1));
+ unocc = 0;
+ for (i = 0; i < LENGTH(tags); ++i) {
+ while (unocc < i && (occ & (1 << unocc)))
+ unocc++;
+ if (occ & (1 << i)) {
+ tagdest[i] = unocc;
+ occ &= ~(1 << i);
+ occ |= 1 << unocc;
+ }
+ }
+
+ for (c = selmon->clients; c; c = c->next)
+ c->tags = 1 << tagdest[ffs(c->tags)-1];
+ if (selmon->sel)
+ selmon->tagset[selmon->seltags] = selmon->sel->tags;
+ arrange(selmon);
+}
+
void
resize(Client *c, int x, int y, int w, int h, int interact)
{