about summary refs log tree commit diff stats
path: root/view.c
diff options
context:
space:
mode:
authorAnselm R. Garbe <arg@10kloc.org>2006-10-06 11:37:12 +0200
committerAnselm R. Garbe <arg@10kloc.org>2006-10-06 11:37:12 +0200
commitacdea319162a5a51703a88ca7a8a1b17534be616 (patch)
tree260efb57888de18da3e03124f4a1e258e85cdd61 /view.c
parent10885d349a8426f0a55f34e78a2592267e8e55be (diff)
downloaddwm-acdea319162a5a51703a88ca7a8a1b17534be616.tar.gz
yet another small fix and simplification of dotile
Diffstat (limited to 'view.c')
-rw-r--r--view.c28
1 files changed, 10 insertions, 18 deletions
diff --git a/view.c b/view.c
index 0f9cb68..b2f2614 100644
--- a/view.c
+++ b/view.c
@@ -95,28 +95,23 @@ dofloat(Arg *arg) {
 	restack();
 }
 
-/* This algorithm is based on a (M)aster area and a (S)tacking area.
- * It supports following arrangements:
- * 	SSMMM	MMMMM	MMMSS
- * 	SSMMM	SSSSS	MMMSS
- */
 void
 dotile(Arg *arg) {
-	unsigned int i, n, md, stackw, stackh, th;
+	unsigned int i, n, mpx, stackw, stackh, th;
 	Client *c;
 
 	for(n = 0, c = nexttiled(clients); c; c = nexttiled(c->next))
 		n++;
 
-	md = (sw * master) / 1000;
-	stackw = sw - md;
+	mpx = (sw * master) / 1000;
+	stackw = sw - mpx;
 	stackh = sh - bh;
 
 	th = stackh;
 	if(n > 1)
 		th /= (n - 1);
 
-	for(i = 0, c = clients; c; c = c->next) {
+	for(i = 0, c = clients; c; c = c->next, i++)
 		if(isvisible(c)) {
 			if(c->isfloat) {
 				resize(c, True, TopLeft);
@@ -130,29 +125,26 @@ dotile(Arg *arg) {
 				c->h = sh - 2 * BORDERPX - bh;
 			}
 			else if(i == 0) { /* master window */
-				c->w = md - 2 * BORDERPX;
+				c->w = mpx - 2 * BORDERPX;
 				c->h = sh - bh - 2 * BORDERPX;
 			}
 			else {  /* tile window */
-				c->x += md;
+				c->x += mpx;
+				c->w = stackw - 2 * BORDERPX;
 				if(th > bh) {
 					c->y = sy + (i - 1) * th + bh;
 					if(i + 1 == n)
 						c->h = sh - c->y - 2 * BORDERPX;
-					c->w = stackw - 2 * BORDERPX;
-					c->h = th - 2 * BORDERPX;
+					else
+						c->h = th - 2 * BORDERPX;
 				}
-				else { /* fallback if th < bh */
-					c->w = stackw - 2 * BORDERPX;
+				else /* fallback if th < bh */
 					c->h = stackh - 2 * BORDERPX;
-				}
 			}
 			resize(c, False, TopLeft);
-			i++;
 		}
 		else
 			ban(c);
-	}
 	if(!sel || !isvisible(sel)) {
 		for(c = stack; c && !isvisible(c); c = c->snext);
 		focus(c);
;vc@akkartik.com> 2015-07-13 22:50:49 -0700 1780 - now we always reclaim local scopes' href='/akkartik/mu/commit/074console.mu?h=main&id=77d5b5d658830bd24724f945e0d6ddf6a06adc0e'>77d5b5d6 ^
45c08fea ^
fb5470bc ^
502d2ea5 ^



e3092e7b ^

45c08fea ^
77d5b5d6 ^
45c08fea ^
e3092e7b ^
502d2ea5 ^


e3092e7b ^
502d2ea5 ^


45c08fea ^
502d2ea5 ^
e3092e7b ^
502d2ea5 ^


e3092e7b ^
6aa42628 ^
45c08fea ^
502d2ea5 ^
e3092e7b ^

c6c19a27 ^


45c08fea ^
77d5b5d6 ^
1fa53058 ^
502d2ea5 ^





e3092e7b ^
f8c0ef3e ^

77d5b5d6 ^
1fa53058 ^
f8c0ef3e ^
1fa53058 ^
f8c0ef3e ^
502d2ea5 ^





f8c0ef3e ^

502d2ea5 ^
f8c0ef3e ^
6a0f71b9 ^

77d5b5d6 ^
1fa53058 ^
6a0f71b9 ^
502d2ea5 ^

6a0f71b9 ^
502d2ea5 ^
6a0f71b9 ^
5e9eff8c ^


77d5b5d6 ^
1fa53058 ^
5e9eff8c ^
502d2ea5 ^
5e9eff8c ^
bc643692 ^
5e9eff8c ^

502d2ea5 ^
5e9eff8c ^
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113