Adding transfer patch
parent
60209c98d7
commit
84b0361b65
@ -0,0 +1,33 @@
|
|||||||
|
void
|
||||||
|
transfer(const Arg *arg)
|
||||||
|
{
|
||||||
|
Client *c, *mtail = selmon->clients, *stail = NULL, *insertafter;
|
||||||
|
int transfertostack = 0, i, nmasterclients;
|
||||||
|
|
||||||
|
for (i = 0, c = selmon->clients; c; c = c->next) {
|
||||||
|
if (!ISVISIBLE(c) || c->isfloating) continue;
|
||||||
|
if (selmon->sel == c) { transfertostack = i < selmon->nmaster && selmon->nmaster != 0; }
|
||||||
|
if (i < selmon->nmaster) { nmasterclients++; mtail = c; }
|
||||||
|
stail = c;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
if (selmon->sel->isfloating || i == 0) {
|
||||||
|
return;
|
||||||
|
} else if (transfertostack) {
|
||||||
|
selmon->nmaster = MIN(i, selmon->nmaster) - 1;
|
||||||
|
insertafter = stail;
|
||||||
|
} else {
|
||||||
|
selmon->nmaster = selmon->nmaster + 1;
|
||||||
|
insertafter = mtail;
|
||||||
|
}
|
||||||
|
if (insertafter != selmon->sel) {
|
||||||
|
detach(selmon->sel);
|
||||||
|
if (selmon->nmaster == 1 && !transfertostack) {
|
||||||
|
attach(selmon->sel); // Head prepend case
|
||||||
|
} else {
|
||||||
|
selmon->sel->next = insertafter->next;
|
||||||
|
insertafter->next = selmon->sel;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
arrange(selmon);
|
||||||
|
}
|
@ -0,0 +1 @@
|
|||||||
|
static void transfer(const Arg *arg);
|
Loading…
Reference in New Issue