# HG changeset patch # User Anselm R. Garbe # Date 1152815299 -7200 # Node ID d18f6dd0cf2391e837a1afc296a04ed64bfa9013 # Parent 035617ee18d1a8aaa4589095e53b15f7aea5e4de fixed several things, nearly feature complete diff -r 035617ee18d1 -r d18f6dd0cf23 TODO --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/TODO Thu Jul 13 20:28:19 2006 +0200 @@ -0,0 +1,1 @@ +- improve mouse based resizals with quadrant approach (then I think we have feature completeness already) diff -r 035617ee18d1 -r d18f6dd0cf23 client.c --- a/client.c Thu Jul 13 19:55:07 2006 +0200 +++ b/client.c Thu Jul 13 20:28:19 2006 +0200 @@ -52,7 +52,7 @@ sel->w = sw - 2 * sel->border; sel->h = sh - 2 * sel->border; craise(sel); - resize(sel); + resize(sel, False); discard_events(EnterWindowMask); } @@ -100,7 +100,7 @@ arrange = floating; for(c = clients; c; c = c->next) { if(c->tags[tsel]) - resize(c); + resize(c, True); else ban_client(c); } @@ -125,29 +125,29 @@ if(c->tags[tsel]) n++; - h = (n > 2) ? sh / (n - 2) : sh; + h = (n > 1) ? sh / (n - 1) : sh; for(i = 0, c = clients; c; c = c->next) { if(c->tags[tsel]) { if(n == 1) { c->x = sx; c->y = sy; - c->w = sw; - c->h = sh; + c->w = sw - 2 * c->border; + c->h = sh - 2 * c->border; } - else if(i == 1) { + else if(i == 0) { c->x = sx; c->y = sy; - c->w = mw; - c->h = sh; + c->w = mw - 2 * c->border; + c->h = sh - 2 * c->border; } else { c->x = sx + mw; - c->y = sy + (i - 2) * h; - c->w = w; - c->h = h; + c->y = sy + (i - 1) * h; + c->w = w - 2 * c->border; + c->h = h - 2 * c->border; } - resize(c); + resize(c, False); i++; } else @@ -304,14 +304,11 @@ void focus(Client *c) { - if(sel && sel != c) { - XSetWindowBorder(dpy, sel->win, dc.bg); - XMapWindow(dpy, sel->title); - draw_client(sel); - } + Client *old = sel; + sel = c; - XUnmapWindow(dpy, c->title); - XSetWindowBorder(dpy, c->win, dc.fg); + if(old && old != c) + draw_client(old); draw_client(c); XSetInputFocus(dpy, c->win, RevertToPointerRoot, CurrentTime); XFlush(dpy); @@ -463,14 +460,16 @@ void -resize(Client *c) +resize(Client *c, Bool inc) { XConfigureEvent e; - if(c->incw) - c->w -= (c->w - c->basew) % c->incw; - if(c->inch) - c->h -= (c->h - c->baseh) % c->inch; + if(inc) { + 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) @@ -554,8 +553,14 @@ draw_client(Client *c) { int i; - if(c == sel) + if(c == sel) { + XUnmapWindow(dpy, c->title); + XSetWindowBorder(dpy, c->win, dc.fg); return; + } + + XSetWindowBorder(dpy, c->win, dc.bg); + XMapWindow(dpy, c->title); dc.x = dc.y = 0; dc.h = c->th; diff -r 035617ee18d1 -r d18f6dd0cf23 dev.c --- a/dev.c Thu Jul 13 19:55:07 2006 +0200 +++ b/dev.c Thu Jul 13 20:28:19 2006 +0200 @@ -104,7 +104,7 @@ c->h = abs(ocy - ev.xmotion.y); c->x = (ocx <= ev.xmotion.x) ? ocx : ocx - c->w; c->y = (ocy <= ev.xmotion.y) ? ocy : ocy - c->h; - resize(c); + resize(c, True); break; case ButtonRelease: XUngrabPointer(dpy, CurrentTime); @@ -138,7 +138,7 @@ XFlush(dpy); c->x = ocx + (ev.xmotion.x - x1); c->y = ocy + (ev.xmotion.y - y1); - resize(c); + resize(c, False); break; case ButtonRelease: XUngrabPointer(dpy, CurrentTime); diff -r 035617ee18d1 -r d18f6dd0cf23 dwm.h --- a/dwm.h Thu Jul 13 19:55:07 2006 +0200 +++ b/dwm.h Thu Jul 13 20:28:19 2006 +0200 @@ -106,7 +106,7 @@ extern void focus(Client *c); extern void update_name(Client *c); extern void draw_client(Client *c); -extern void resize(Client *c); +extern void resize(Client *c, Bool inc); extern void update_size(Client *c); extern Client *gettitle(Window w); extern void craise(Client *c); diff -r 035617ee18d1 -r d18f6dd0cf23 main.c --- a/main.c Thu Jul 13 19:55:07 2006 +0200 +++ b/main.c Thu Jul 13 20:28:19 2006 +0200 @@ -168,7 +168,7 @@ cleanup() { while(sel) { - resize(sel); + resize(sel, True); unmanage(sel); } XSetInputFocus(dpy, PointerRoot, RevertToPointerRoot, CurrentTime);