Compare commits
6 Commits
654d526235
...
164ff48dd4
Author | SHA1 | Date | |
---|---|---|---|
164ff48dd4 | |||
d00a5f3227 | |||
1e391a31fd | |||
|
90da2ddac4 | ||
|
b0c010ec9a | ||
f463bb987f |
2
dwm.c
2
dwm.c
@ -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)
|
||||||
|
58
patches/behavior/dwm-reorganizetags-6.2.diff
Normal file
58
patches/behavior/dwm-reorganizetags-6.2.diff
Normal 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)
|
||||||
|
{
|
Loading…
Reference in New Issue
Block a user