|
|
|
@ -3,31 +3,39 @@
|
|
|
|
|
* See LICENSE file for license details.
|
|
|
|
|
*/
|
|
|
|
|
#include "dwm.h"
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
|
|
/* static */
|
|
|
|
|
|
|
|
|
|
static Client *
|
|
|
|
|
minclient()
|
|
|
|
|
{
|
|
|
|
|
Client *c, *min;
|
|
|
|
|
|
|
|
|
|
for(min = c = clients; c; c = c->next)
|
|
|
|
|
if(c->weight < min->weight)
|
|
|
|
|
min = c;
|
|
|
|
|
return min;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
reorder()
|
|
|
|
|
{
|
|
|
|
|
Client *c, *orig, *p;
|
|
|
|
|
Client *c, *newclients, *tail;
|
|
|
|
|
|
|
|
|
|
orig = clients;
|
|
|
|
|
clients = NULL;
|
|
|
|
|
|
|
|
|
|
while((c = orig)) {
|
|
|
|
|
orig = orig->next;
|
|
|
|
|
newclients = tail = NULL;
|
|
|
|
|
while((c = minclient())) {
|
|
|
|
|
detach(c);
|
|
|
|
|
|
|
|
|
|
for(p = clients; p && p->next && p->weight <= c->weight; p = p->next);
|
|
|
|
|
c->prev = p;
|
|
|
|
|
if(p) {
|
|
|
|
|
if((c->next = p->next))
|
|
|
|
|
c->next->prev = c;
|
|
|
|
|
p->next = c;
|
|
|
|
|
if(tail) {
|
|
|
|
|
c->prev = tail;
|
|
|
|
|
tail->next = c;
|
|
|
|
|
tail = c;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
clients = c;
|
|
|
|
|
tail = newclients = c;
|
|
|
|
|
}
|
|
|
|
|
clients = newclients;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* extern */
|
|
|
|
@ -59,9 +67,7 @@ dofloat(Arg *arg)
|
|
|
|
|
else
|
|
|
|
|
ban(c);
|
|
|
|
|
}
|
|
|
|
|
if(!sel || !isvisible(sel))
|
|
|
|
|
sel = getnext(clients);
|
|
|
|
|
if(sel)
|
|
|
|
|
if((sel = getnext(clients)))
|
|
|
|
|
focus(sel);
|
|
|
|
|
else
|
|
|
|
|
XSetInputFocus(dpy, root, RevertToPointerRoot, CurrentTime);
|
|
|
|
@ -124,9 +130,7 @@ dotile(Arg *arg)
|
|
|
|
|
else
|
|
|
|
|
ban(c);
|
|
|
|
|
}
|
|
|
|
|
if(!sel || !isvisible(sel))
|
|
|
|
|
sel = getnext(clients);
|
|
|
|
|
if(sel)
|
|
|
|
|
if((sel = getnext(clients)))
|
|
|
|
|
focus(sel);
|
|
|
|
|
else
|
|
|
|
|
XSetInputFocus(dpy, root, RevertToPointerRoot, CurrentTime);
|
|
|
|
|