add tag reo-organiuzation to resetlayout
This commit is contained in:
parent
e1874b34c1
commit
44206a27f3
30
dwm.c
30
dwm.c
@ -224,6 +224,7 @@ static void pop(Client *c);
|
|||||||
static void propertynotify(XEvent *e);
|
static void propertynotify(XEvent *e);
|
||||||
static void quit(const Arg *arg);
|
static void quit(const Arg *arg);
|
||||||
static Monitor *recttomon(int x, int y, int w, int h);
|
static Monitor *recttomon(int x, int y, int w, int h);
|
||||||
|
static void reorganizetags(const Arg *arg);
|
||||||
static void resetlayout(const Arg *arg);
|
static void resetlayout(const Arg *arg);
|
||||||
static void resize(Client *c, int x, int y, int w, int h, int interact);
|
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 resizeclient(Client *c, int x, int y, int w, int h);
|
||||||
@ -1797,6 +1798,35 @@ resetlayout(const Arg *arg)
|
|||||||
|
|
||||||
selmon->nmaster = selmon->pertag->nmasters[selmon->pertag->curtag] = nmaster;
|
selmon->nmaster = selmon->pertag->nmasters[selmon->pertag->curtag] = nmaster;
|
||||||
arrange(selmon);
|
arrange(selmon);
|
||||||
|
|
||||||
|
reorganizetags(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
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
|
void
|
||||||
|
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