aewl
changeset 522:fd1275f3b205
simplified dotile()
author | Anselm R. Garbe <arg@10kloc.org> |
---|---|
date | Thu, 05 Oct 2006 12:13:24 +0200 (2006-10-05) |
parents | 73afe7587bea |
children | c1dd19da63ef |
files | dwm.h view.c |
diffstat | 2 files changed, 20 insertions(+), 37 deletions(-) [+] |
line diff
1.1 --- a/dwm.h Thu Oct 05 11:00:55 2006 +0200 1.2 +++ b/dwm.h Thu Oct 05 12:13:24 2006 +0200 1.3 @@ -40,7 +40,6 @@ 1.4 #define MOUSEMASK (BUTTONMASK | PointerMotionMask) 1.5 /* other stuff used in different places */ 1.6 #define BORDERPX 1 1.7 -#define MINW 100 1.8 #define PROTODELWIN 1 1.9 1.10 enum { NetSupported, NetWMName, NetLast }; /* EWMH atoms */
2.1 --- a/view.c Thu Oct 05 11:00:55 2006 +0200 2.2 +++ b/view.c Thu Oct 05 12:13:24 2006 +0200 2.3 @@ -4,6 +4,8 @@ 2.4 */ 2.5 #include "dwm.h" 2.6 2.7 +#define MINDIM 100 2.8 + 2.9 /* static */ 2.10 2.11 static Client * 2.12 @@ -138,69 +140,51 @@ 2.13 c->h = sh - 2 * BORDERPX - bh; 2.14 } 2.15 else if(i == 0) { /* master window */ 2.16 + c->x = sx; 2.17 + if(stackpos == StackLeft) 2.18 + c->x += stackw; 2.19 + c->y = sy + bh; 2.20 switch(stackpos) { 2.21 case StackLeft: 2.22 - c->x = sx + stackw; 2.23 - c->y = sy + bh; 2.24 + case StackRight: 2.25 c->w = master - 2 * BORDERPX; 2.26 c->h = sh - bh - 2 * BORDERPX; 2.27 break; 2.28 case StackBottom: 2.29 - c->x = sx; 2.30 - c->y = sy + bh; 2.31 c->w = sw - 2 * BORDERPX; 2.32 c->h = master - 2 * BORDERPX; 2.33 break; 2.34 - case StackRight: 2.35 - c->x = sx; 2.36 - c->y = sy + bh; 2.37 - c->w = master - 2 * BORDERPX; 2.38 - c->h = sh - bh - 2 * BORDERPX; 2.39 - break; 2.40 } 2.41 } 2.42 - else if(th > bh) { 2.43 - /* tile window */ 2.44 + else if(th > bh) { /* tile window */ 2.45 + c->x = sx; 2.46 + if(stackpos == StackRight) 2.47 + c->x += master; 2.48 c->w = tw - 2 * BORDERPX; 2.49 c->h = th - 2 * BORDERPX; 2.50 switch(stackpos) { 2.51 case StackLeft: 2.52 - c->x = sx; 2.53 + case StackRight: 2.54 c->y = sy + (i - 1) * th + bh; 2.55 if(i + 1 == n) 2.56 c->h = sh - c->y - 2 * BORDERPX; 2.57 break; 2.58 case StackBottom: 2.59 - c->x = sx; 2.60 c->y = sy + master + (i - 1) * th + bh; 2.61 if(i + 1 == n) 2.62 c->h = sh - c->y - 2 * BORDERPX; 2.63 break; 2.64 - case StackRight: 2.65 - c->x = sx + master; 2.66 - c->y = sy + (i - 1) * th + bh; 2.67 - if(i + 1 == n) 2.68 - c->h = sh - c->y - 2 * BORDERPX; 2.69 - break; 2.70 } 2.71 } 2.72 else { /* fallback if th < bh */ 2.73 + c->x = sx; 2.74 + if(stackpos == StackRight) 2.75 + c->x += master; 2.76 + c->y = sy + bh; 2.77 + if(stackpos == StackBottom) 2.78 + c->y += master; 2.79 c->w = stackw - 2 * BORDERPX; 2.80 c->h = stackh - 2 * BORDERPX; 2.81 - switch(stackpos) { 2.82 - case StackLeft: 2.83 - c->x = sx; 2.84 - c->y = sy + bh; 2.85 - break; 2.86 - case StackBottom: 2.87 - c->x = sx; 2.88 - c->y = sy + master + bh; 2.89 - break; 2.90 - case StackRight: 2.91 - c->x = sx + master; 2.92 - c->y = sy + bh; 2.93 - break; 2.94 - } 2.95 } 2.96 resize(c, False, TopLeft); 2.97 i++; 2.98 @@ -271,12 +255,12 @@ 2.99 2.100 s = stackpos == StackBottom ? sh - bh : sw; 2.101 if(sel == getnext(clients)) { 2.102 - if(master + arg->i > s - MINW || master + arg->i < MINW) 2.103 + if(master + arg->i > s - MINDIM || master + arg->i < MINDIM) 2.104 return; 2.105 master += arg->i; 2.106 } 2.107 else { 2.108 - if(master - arg->i > s - MINW || master - arg->i < MINW) 2.109 + if(master - arg->i > s - MINDIM || master - arg->i < MINDIM) 2.110 return; 2.111 master -= arg->i; 2.112 }