aewl

changeset 429:a31de8605f72

no, ordering floating clients at the end seems better
author Anselm R. Garbe <arg@10kloc.org>
date Tue, 05 Sep 2006 19:26:34 +0200 (2006-09-05)
parents 16f8f05f960e
children 1e8aba00964e
files client.c tag.c view.c
diffstat 3 files changed, 17 insertions(+), 19 deletions(-) [+]
line diff
     1.1 --- a/client.c	Tue Sep 05 18:43:15 2006 +0200
     1.2 +++ b/client.c	Tue Sep 05 19:26:34 2006 +0200
     1.3 @@ -247,6 +247,8 @@
     1.4  		c->isfloat = trans
     1.5  			|| (c->maxw && c->minw &&
     1.6  				c->maxw == c->minw && c->maxh == c->minh);
     1.7 +	if(c->isfloat)
     1.8 +		c->weight = ntags;
     1.9  
    1.10  	if(clients)
    1.11  		clients->prev = c;
     2.1 --- a/tag.c	Tue Sep 05 18:43:15 2006 +0200
     2.2 +++ b/tag.c	Tue Sep 05 19:26:34 2006 +0200
     2.3 @@ -106,7 +106,8 @@
     2.4  	if(!matched)
     2.5  		for(i = 0; i < ntags; i++)
     2.6  			c->tags[i] = seltag[i];
     2.7 -	for(c->weight = 0; c->weight < ntags && !c->tags[c->weight]; c->weight++);
     2.8 +	if(!c->isfloat)
     2.9 +		for(c->weight = 0; c->weight < ntags && !c->tags[c->weight]; c->weight++);
    2.10  }
    2.11  
    2.12  void
    2.13 @@ -120,7 +121,8 @@
    2.14  	for(i = 0; i < ntags; i++)
    2.15  		sel->tags[i] = False;
    2.16  	sel->tags[arg->i] = True;
    2.17 -	sel->weight = arg->i;
    2.18 +	if(!sel->isfloat)
    2.19 +		sel->weight = arg->i;
    2.20  	arrange(NULL);
    2.21  }
    2.22  
    2.23 @@ -136,6 +138,7 @@
    2.24  	for(i = 0; i < ntags && !sel->tags[i]; i++);
    2.25  	if(i == ntags)
    2.26  		sel->tags[arg->i] = True;
    2.27 -	sel->weight = (i == ntags) ? arg->i : i;
    2.28 +	if(!sel->isfloat)
    2.29 +		sel->weight = (i == ntags) ? arg->i : i;
    2.30  	arrange(NULL);
    2.31  }
     3.1 --- a/view.c	Tue Sep 05 18:43:15 2006 +0200
     3.2 +++ b/view.c	Tue Sep 05 19:26:34 2006 +0200
     3.3 @@ -82,8 +82,8 @@
     3.4  	maximized = False;
     3.5  
     3.6  	w = sw - mw;
     3.7 -	for(n = 0, c = clients; c; c = c->next)
     3.8 -		if(isvisible(c) && !c->isfloat)
     3.9 +	for(n = 0, c = clients; c && !c->isfloat; c = c->next)
    3.10 +		if(isvisible(c))
    3.11  			n++;
    3.12  
    3.13  	if(n > 1)
    3.14 @@ -186,8 +186,8 @@
    3.15  	unsigned int n;
    3.16  	Client *c;
    3.17  
    3.18 -	for(n = 0, c = clients; c; c = c->next)
    3.19 -		if(isvisible(c) && !c->isfloat)
    3.20 +	for(n = 0, c = clients; c && !c->isfloat; c = c->next)
    3.21 +		if(isvisible(c))
    3.22  			n++;
    3.23  	if(!sel || sel->isfloat || n < 2 || (arrange != dotile) || maximized)
    3.24  		return;
    3.25 @@ -311,22 +311,15 @@
    3.26  	unsigned int n;
    3.27  	Client *c;
    3.28  
    3.29 -	for(n = 0, c = clients; c; c = c->next)
    3.30 -		if(isvisible(c) && !c->isfloat)
    3.31 +	for(n = 0, c = clients; c && !c->isfloat; c = c->next)
    3.32 +		if(isvisible(c))
    3.33  			n++;
    3.34  	if(!sel || sel->isfloat || n < 2 || (arrange != dotile) || maximized)
    3.35  		return;
    3.36  
    3.37 -	/* this is somewhat tricky, it asserts to only zoom tiled clients */
    3.38 -	for(c = getnext(clients); c && c->isfloat; c = getnext(c->next));
    3.39 -	if(c) {
    3.40 -		if(c == sel)
    3.41 -			for(c = getnext(c->next); c && c->isfloat; c = getnext(c->next));
    3.42 -		else
    3.43 -			c = sel;
    3.44 -	}
    3.45 -	if(!c)
    3.46 -		return;
    3.47 +	if((c = sel) == getnext(clients))
    3.48 +		if(!(c = getnext(c->next)) || c->isfloat)
    3.49 +			return;
    3.50  	detach(c);
    3.51  	c->next = clients;
    3.52  	clients->prev = c;