improved selection policy
This commit is contained in:
parent
9d73909075
commit
c3c94c0e0a
44
view.c
44
view.c
|
@ -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);
|
||||
|
|
Loading…
Reference in a new issue