forked from github/lukesmith-dwm
		
	fibonacci patch
This commit is contained in:
		
							parent
							
								
									23d66b0e0b
								
							
						
					
					
						commit
						336c411392
					
				| @ -37,6 +37,7 @@ static const float mfact     = 0.55; /* factor of master area size [0.05..0.95] | ||||
| static const int nmaster     = 1;    /* number of clients in master area */ | ||||
| static const int resizehints = 1;    /* 1 means respect size hints in tiled resizals */ | ||||
| 
 | ||||
| #include "fibonacci.c" | ||||
| static const Layout layouts[] = { | ||||
| 	/* symbol     arrange function */ | ||||
| 	{ "[]=",      tile },    /* first entry is default */ | ||||
| @ -44,6 +45,8 @@ static const Layout layouts[] = { | ||||
| 	{ "[M]",      monocle }, | ||||
| 	{ "|M|",      centeredmaster }, | ||||
| 	{ ">M>",      centeredfloatingmaster }, | ||||
|  	{ "[@]",      spiral }, | ||||
|  	{ "[\\]",      dwindle }, | ||||
| }; | ||||
| 
 | ||||
| /* key definitions */ | ||||
|  | ||||
							
								
								
									
										66
									
								
								fibonacci.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								fibonacci.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,66 @@ | ||||
| void | ||||
| fibonacci(Monitor *mon, int s) { | ||||
| 	unsigned int i, n, nx, ny, nw, nh; | ||||
| 	Client *c; | ||||
| 
 | ||||
| 	for(n = 0, c = nexttiled(mon->clients); c; c = nexttiled(c->next), n++); | ||||
| 	if(n == 0) | ||||
| 		return; | ||||
| 	 | ||||
| 	nx = mon->wx; | ||||
| 	ny = 0; | ||||
| 	nw = mon->ww; | ||||
| 	nh = mon->wh; | ||||
| 	 | ||||
| 	for(i = 0, c = nexttiled(mon->clients); c; c = nexttiled(c->next)) { | ||||
| 		if((i % 2 && nh / 2 > 2 * c->bw) | ||||
| 		   || (!(i % 2) && nw / 2 > 2 * c->bw)) { | ||||
| 			if(i < n - 1) { | ||||
| 				if(i % 2) | ||||
| 					nh /= 2; | ||||
| 				else | ||||
| 					nw /= 2; | ||||
| 				if((i % 4) == 2 && !s) | ||||
| 					nx += nw; | ||||
| 				else if((i % 4) == 3 && !s) | ||||
| 					ny += nh; | ||||
| 			} | ||||
| 			if((i % 4) == 0) { | ||||
| 				if(s) | ||||
| 					ny += nh; | ||||
| 				else | ||||
| 					ny -= nh; | ||||
| 			} | ||||
| 			else if((i % 4) == 1) | ||||
| 				nx += nw; | ||||
| 			else if((i % 4) == 2) | ||||
| 				ny += nh; | ||||
| 			else if((i % 4) == 3) { | ||||
| 				if(s) | ||||
| 					nx += nw; | ||||
| 				else | ||||
| 					nx -= nw; | ||||
| 			} | ||||
| 			if(i == 0) | ||||
| 			{ | ||||
| 				if(n != 1) | ||||
| 					nw = mon->ww * mon->mfact; | ||||
| 				ny = mon->wy; | ||||
| 			} | ||||
| 			else if(i == 1) | ||||
| 				nw = mon->ww - nw; | ||||
| 			i++; | ||||
| 		} | ||||
| 		resize(c, nx, ny, nw - 2 * c->bw, nh - 2 * c->bw, False); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| void | ||||
| dwindle(Monitor *mon) { | ||||
| 	fibonacci(mon, 1); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| spiral(Monitor *mon) { | ||||
| 	fibonacci(mon, 0); | ||||
| } | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user