Adding focusmaster-return patch variant ref. #398
parent
d86ea2de25
commit
817db8c3ca
@ -1,14 +1,41 @@
|
|||||||
void
|
void
|
||||||
focusmaster(const Arg *arg)
|
focusmaster(const Arg *arg)
|
||||||
{
|
{
|
||||||
Client *c;
|
Client *master;
|
||||||
|
Monitor *m = selmon;
|
||||||
|
#if FOCUSMASTER_RETURN_PATCH
|
||||||
|
int i;
|
||||||
|
#endif // FOCUSMASTER_RETURN_PATCH
|
||||||
|
|
||||||
if (selmon->nmaster < 1)
|
if (m->nmaster < 1)
|
||||||
return;
|
return;
|
||||||
|
#if !FAKEFULLSCREEN_PATCH
|
||||||
|
#if FAKEFULLSCREEN_CLIENT_PATCH
|
||||||
|
if (!m->sel || (m->sel->isfullscreen && m->sel->fakefullscreen != 1 && lockfullscreen))
|
||||||
|
return;
|
||||||
|
#else
|
||||||
|
if (!m->sel || (m->sel->isfullscreen && lockfullscreen))
|
||||||
|
return;
|
||||||
|
#endif // FAKEFULLSCREEN_CLIENT_PATCH
|
||||||
|
#endif // FAKEFULLSCREEN_PATCH
|
||||||
|
|
||||||
c = nexttiled(selmon->clients);
|
master = nexttiled(m->clients);
|
||||||
|
|
||||||
if (c)
|
if (!master)
|
||||||
focus(c);
|
return;
|
||||||
}
|
|
||||||
|
#if FOCUSMASTER_RETURN_PATCH
|
||||||
|
for (i = 0; !(m->tagset[m->seltags] & 1 << i); i++);
|
||||||
|
i++;
|
||||||
|
|
||||||
|
if (m->sel == master) {
|
||||||
|
if (m->tagmarked[i] && ISVISIBLE(m->tagmarked[i]))
|
||||||
|
focus(m->tagmarked[i]);
|
||||||
|
} else {
|
||||||
|
m->tagmarked[i] = m->sel;
|
||||||
|
focus(master);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
focus(master);
|
||||||
|
#endif // FOCUSMASTER_RETURN_PATCH
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue