about summary refs log tree commit diff stats
diff options
context:
space:
mode:
-rw-r--r--view.c17
1 files changed, 12 insertions, 5 deletions
diff --git a/view.c b/view.c
index 06aed3e..4513a45 100644
--- a/view.c
+++ b/view.c
@@ -75,11 +75,16 @@ dotile(void) {
 
 	for(n = 0, c = nexttiled(clients); c; c = nexttiled(c->next))
 		n++;
+
 	/* window geoms */
-	mw = (n > nmaster) ? (waw * master) / 1000 : waw;
-	mh = (n > nmaster) ? wah / nmaster : wah / (n > 0 ? n : 1);
-	tw = waw - mw;
+	if(nmaster > 0) {
+		mh = (n > nmaster) ?  wah / nmaster : wah / (n > 0 ? n : 1);
+		mw = (n > nmaster) ? (waw * master) / 1000 : waw;
+	}
+	else
+		mh = mw = 0;
 	th = (n > nmaster) ? wah / (n - nmaster) : 0;
+	tw = waw - mw;
 
 	for(i = 0, c = clients; c; c = c->next)
 		if(isvisible(c)) {
@@ -90,7 +95,7 @@ dotile(void) {
 			c->ismax = False;
 			c->x = wax;
 			c->y = way;
-			if(i < nmaster) {
+			if((nmaster > 0) && (i < nmaster)) {
 				c->y += i * mh;
 				c->w = mw - 2 * BORDERPX;
 				c->h = mh - 2 * BORDERPX;
@@ -150,7 +155,9 @@ focusprev(Arg *arg) {
 
 void
 incnmaster(Arg *arg) {
-	if((arrange == dofloat) || (nmaster + arg->i < 1) || (wah / (nmaster + arg->i) < bh))
+	if((arrange == dofloat)
+	|| ((int)nmaster + arg->i < 0)
+	|| (((int)nmaster + arg->i > 0) && (wah / (nmaster + arg->i) < bh)))
 		return;
 	nmaster += arg->i;
 	updatemodetext();
cpp/.traces/get_handles_nested_container_elements?h=main&id=c6bea7a010be89fbb464a513180d60200716053e'>^
844697c2 ^
088665ef ^

decaddb4 ^




d61b4761 ^
6ca059ef ^
6f5d7864 ^
6cc46216 ^
57699011 ^
6f5d7864 ^
6cc46216 ^
57699011 ^
6f5d7864 ^
6cc46216 ^
57699011 ^
6f5d7864 ^
6cc46216 ^





57699011 ^
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