2019-09-15 00:22:24 +02:00
|
|
|
static Client *
|
2019-09-14 00:36:18 +02:00
|
|
|
nextc(Client *c, float f)
|
|
|
|
{
|
|
|
|
if (!f)
|
|
|
|
return nexttiled(c);
|
|
|
|
|
|
|
|
for (; c && !ISVISIBLE(c); c = c->next);
|
|
|
|
return c;
|
|
|
|
}
|
|
|
|
|
|
|
|
static Client *
|
|
|
|
prevc(Client *c, float f)
|
|
|
|
{
|
|
|
|
Client *p, *r;
|
|
|
|
|
|
|
|
for (p = selmon->clients, r = NULL; c && p && p != c; p = p->next)
|
|
|
|
if ((f || !p->isfloating) && ISVISIBLE(p))
|
|
|
|
r = p;
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
pushup(const Arg *arg)
|
|
|
|
{
|
|
|
|
Client *sel = selmon->sel;
|
|
|
|
Client *c;
|
|
|
|
|
|
|
|
if (!sel || (sel->isfloating && !arg->f))
|
|
|
|
return;
|
|
|
|
if ((c = prevc(sel, arg->f))) {
|
|
|
|
/* attach before c */
|
|
|
|
detach(sel);
|
|
|
|
sel->next = c;
|
|
|
|
if (selmon->clients == c)
|
|
|
|
selmon->clients = sel;
|
|
|
|
else {
|
2019-09-15 00:43:35 +02:00
|
|
|
for (c = selmon->clients; c->next != sel->next; c = c->next);
|
2019-09-14 00:36:18 +02:00
|
|
|
c->next = sel;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
/* move to the end */
|
|
|
|
for (c = sel; c->next; c = c->next);
|
2022-01-07 22:27:08 +01:00
|
|
|
if (sel != c) {
|
|
|
|
detach(sel);
|
|
|
|
sel->next = NULL;
|
|
|
|
c->next = sel;
|
|
|
|
}
|
2019-09-14 00:36:18 +02:00
|
|
|
}
|
|
|
|
focus(sel);
|
|
|
|
arrange(selmon);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
pushdown(const Arg *arg)
|
|
|
|
{
|
|
|
|
Client *sel = selmon->sel;
|
|
|
|
Client *c;
|
|
|
|
|
|
|
|
if (!sel || (sel->isfloating && !arg->f))
|
|
|
|
return;
|
|
|
|
if ((c = nextc(sel->next, arg->f))) {
|
|
|
|
/* attach after c */
|
|
|
|
detach(sel);
|
|
|
|
sel->next = c->next;
|
|
|
|
c->next = sel;
|
|
|
|
} else {
|
|
|
|
/* move to the front */
|
|
|
|
detach(sel);
|
|
|
|
attach(sel);
|
|
|
|
}
|
|
|
|
focus(sel);
|
|
|
|
arrange(selmon);
|
2021-06-14 08:16:17 +03:00
|
|
|
}
|
|
|
|
|