applied sanders no_sizehints for tiled mode patch (thx!)
authorarg@10ksloc.org <unknown>
Thu, 20 Jul 2006 17:09:11 +0000 (19:09 +0200)
committerarg@10ksloc.org <unknown>
Thu, 20 Jul 2006 17:09:11 +0000 (19:09 +0200)
client.c
dwm.h

index 89ca5fb6ed31f3ccef39d0798d45fd0cb9918952..4afa70526c6391f356859984899f9fb0c7a63199 100644 (file)
--- a/client.c
+++ b/client.c
@@ -293,30 +293,30 @@ pop(Client *c)
 }
 
 void
-resize(Client *c, Bool inc, Corner sticky)
+resize(Client *c, Bool sizehints, Corner sticky)
 {
        int bottom = c->y + c->h;
        int right = c->x + c->w;
        XConfigureEvent e;
 
-       if(inc) {
+       if(sizehints) {
                if(c->incw)
                        c->w -= (c->w - c->basew) % c->incw;
                if(c->inch)
                        c->h -= (c->h - c->baseh) % c->inch;
+               if(c->minw && c->w < c->minw)
+                       c->w = c->minw;
+               if(c->minh && c->h < c->minh)
+                       c->h = c->minh;
+               if(c->maxw && c->w > c->maxw)
+                       c->w = c->maxw;
+               if(c->maxh && c->h > c->maxh)
+                       c->h = c->maxh;
        }
        if(c->x > sw) /* might happen on restart */
                c->x = sw - c->w;
        if(c->y > sh)
                c->y = sh - c->h;
-       if(c->minw && c->w < c->minw)
-               c->w = c->minw;
-       if(c->minh && c->h < c->minh)
-               c->h = c->minh;
-       if(c->maxw && c->w > c->maxw)
-               c->w = c->maxw;
-       if(c->maxh && c->h > c->maxh)
-               c->h = c->maxh;
        if(sticky == TopRight || sticky == BotRight)
                c->x = right - c->w;
        if(sticky == BotLeft || sticky == BotRight)
diff --git a/dwm.h b/dwm.h
index 8a7237c8820d33ea8fcc96a88106d28de17272e7..1439f59dc58fce1c02f7466cdf9cf9c390545efe 100644 (file)
--- a/dwm.h
+++ b/dwm.h
@@ -106,7 +106,7 @@ extern void killclient(Arg *arg);
 extern void lower(Client *c);
 extern void manage(Window w, XWindowAttributes *wa);
 extern void pop(Client *c);
-extern void resize(Client *c, Bool inc, Corner sticky);
+extern void resize(Client *c, Bool sizehints, Corner sticky);
 extern void setsize(Client *c);
 extern void settitle(Client *c);
 extern void togglemax(Arg *arg);