[hackers] [dwm] applied Eric Mertens patch to mainstream dwm, however this needs testing

From: Anselm R. Garbe <garbeam_AT_gmail.com>
Date: Tue Oct 16 19:07:49 2007

changeset: 1032:08bc44d1f985
tag: tip
user: Anselm R. Garbe <garbeam_AT_gmail.com>
date: Tue Oct 16 19:07:51 2007 +0200
summary: applied Eric Mertens patch to mainstream dwm, however this needs testing

diff -r 7216ff510041 -r 08bc44d1f985 dwm.c
--- a/dwm.c Tue Oct 16 19:04:49 2007 +0200
+++ b/dwm.c Tue Oct 16 19:07:51 2007 +0200
@@ -1036,39 +1036,42 @@ resize(Client *c, int x, int y, int w, i
         XWindowChanges wc;
 
         if(sizehints) {
- if(c->minay > 0 && c->maxay > 0 && (h - c->baseh) > 0 && (w - c->basew) > 0) {
- dx = (double)(w - c->basew);
- dy = (double)(h - c->baseh);
- min = (double)(c->minax) / (double)(c->minay);
- max = (double)(c->maxax) / (double)(c->maxay);
- ratio = dx / dy;
- if(max > 0 && min > 0 && ratio > 0) {
- if(ratio < min) {
- dy = (dx * min + dy) / (min * min + 1);
- dx = dy * min;
- w = (int)dx + c->basew;
- h = (int)dy + c->baseh;
- }
- else if(ratio > max) {
- dy = (dx * min + dy) / (max * max + 1);
- dx = dy * min;
- w = (int)dx + c->basew;
- h = (int)dy + c->baseh;
- }
- }
- }
- if(c->minw && w < c->minw)
+ /* set minimum possible */
+ if (w < 1)
+ w = 1;
+ if (h < 1)
+ h = 1;
+
+ /* temporarily remove base dimensions */
+ w -= c->basew;
+ h -= c->baseh;
+
+ /* adjust for aspect limits */
+ if (c->minay > 0 && c->maxay > 0 && c->minax > 0 && c->maxax > 0) {
+ if (w * c->maxay > h * c->maxax)
+ w = h * c->maxax / c->maxay;
+ else if (w * c->minay < h * c->minax)
+ h = w * c->minay / c->minax;
+ }
+
+ /* 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;
+
+ if(c->minw > 0 && w < c->minw)
                         w = c->minw;
- if(c->minh && h < c->minh)
+ if(c->minh > 0 && h < c->minh)
                         h = c->minh;
- if(c->maxw && w > c->maxw)
+ if(c->maxw > 0 && w > c->maxw)
                         w = c->maxw;
- if(c->maxh && h > c->maxh)
+ if(c->maxh > 0 && h > c->maxh)
                         h = c->maxh;
- if(c->incw)
- w -= (w - c->basew) % c->incw;
- if(c->inch)
- h -= (h - c->baseh) % c->inch;
         }
         if(w <= 0 || h <= 0)
                 return;
Received on Tue Oct 16 2007 - 19:07:49 UTC

This archive was generated by hypermail 2.2.0 : Sun Jul 13 2008 - 15:58:33 UTC