[hackers] [dwm] applied Gottox' resizehints patch, thanks Gottox! || Anselm R Garbe

From: <hg_AT_suckless.org>
Date: Mon, 2 Mar 2009 10:43:54 +0000 (UTC)

changeset: 1390:c0534213fc52
tag: tip
user: Anselm R Garbe <garbeam_AT_gmail.com>
date: Mon Mar 02 10:43:48 2009 +0000
files: dwm.c
description:
applied Gottox' resizehints patch, thanks Gottox!

diff -r b4e7c220422d -r c0534213fc52 dwm.c
--- a/dwm.c Sat Feb 21 19:20:11 2009 +0000
+++ b/dwm.c Mon Mar 02 10:43:48 2009 +0000
@@ -129,6 +129,7 @@
 
 /* function declarations */
 static void applyrules(Client *c);
+static void applysizehints(Client *c, int *w, int *h);
 static void arrange(void);
 static void attach(Client *c);
 static void attachstack(Client *c);
@@ -268,6 +269,55 @@
         }
         if(!c->tags)
                 c->tags = tagset[seltags];
+}
+
+void
+applysizehints(Client *c, int *w, int *h) {
+ Bool baseismin;
+
+ /* see last two sentences in ICCCM 4.1.2.3 */
+ baseismin = c->basew == c->minw && c->baseh == c->minh;
+
+ /* set minimum possible */
+ *w = MAX(1, *w);
+ *h = MAX(1, *h);
+
+ if(!baseismin) { /* temporarily remove base dimensions */
+ *w -= c->basew;
+ *h -= c->baseh;
+ }
+
+ /* adjust for aspect limits */
+ if(c->mina > 0 && c->maxa > 0) {
+ if(c->maxa < (float)*w / *h)
+ *w = *h * c->maxa;
+ else if(c->mina < (float)*h / *w)
+ *h = *w * c->mina;
+ }
+
+ if(baseismin) { /* increment calculation requires this */
+ *w -= c->basew;
+ *h -= c->baseh;
+ }
+
+ /* adjust for increment value */
+ if(c->incw)
+ *w -= *w % c->incw;
+ if(c->inch)
+ *h -= *h % c->inch;
+
+ /* restore base dimensions */
+ *w += c->basew;
+ *h += c->baseh;
+
+ *w = MAX(*w, c->minw);
+ *h = MAX(*h, c->minh);
+
+ if(c->maxw)
+ *w = MIN(*w, c->maxw);
+
+ if(c->maxh)
+ *h = MIN(*h, c->maxh);
 }
 
 void
@@ -1038,51 +1088,8 @@
 resize(Client *c, int x, int y, int w, int h, Bool sizehints) {
         XWindowChanges wc;
 
- if(sizehints) {
- /* see last two sentences in ICCCM 4.1.2.3 */
- Bool baseismin = c->basew == c->minw && c->baseh == c->minh;
-
- /* set minimum possible */
- w = MAX(1, w);
- h = MAX(1, h);
-
- if(!baseismin) { /* temporarily remove base dimensions */
- w -= c->basew;
- h -= c->baseh;
- }
-
- /* adjust for aspect limits */
- if(c->mina > 0 && c->maxa > 0) {
- if(c->maxa < (float)w / h)
- w = h * c->maxa;
- else if(c->mina < (float)h / w)
- h = w * c->mina;
- }
-
- if(baseismin) { /* increment calculation requires this */
- w -= c->basew;
- h -= c->baseh;
- }
-
- /* adjust for increment value */
- if(c->incw)
- w -= w % c->incw;
- if(c->inch)
- h -= h % c->inch;
-
- /* restore base dimensions */
- w += c->basew;
- h += c->baseh;
-
- w = MAX(w, c->minw);
- h = MAX(h, c->minh);
-
- if(c->maxw)
- w = MIN(w, c->maxw);
-
- if(c->maxh)
- h = MIN(h, c->maxh);
- }
+ if(sizehints)
+ applysizehints(c, &w, &h);
         if(w <= 0 || h <= 0)
                 return;
         if(x > sx + sw)
Received on Mon Mar 02 2009 - 10:43:54 UTC

This archive was generated by hypermail 2.2.0 : Mon Mar 02 2009 - 10:48:04 UTC