added gravity stuff
authorAnselm R. Garbe <garbeam@wmii.de>
Wed, 12 Jul 2006 15:17:15 +0000 (17:17 +0200)
committerAnselm R. Garbe <garbeam@wmii.de>
Wed, 12 Jul 2006 15:17:15 +0000 (17:17 +0200)
client.c
event.c
kb.c
wm.h

index 537336caff514f5510031509375695fc197df682..e9b83fe8d3ed3e4dc5c40ba033b8a5fe41e075f7 100644 (file)
--- a/client.c
+++ b/client.c
@@ -18,9 +18,10 @@ max(void *aux)
                return;
        stack->x = sx;
        stack->y = bh;
-       stack->w = sw - 2;
-       stack->h = sh - bh - 2;
+       stack->w = sw - 2 * stack->border;
+       stack->h = sh - bh - 2 * stack->border;
        resize(stack);
+       discard_events(EnterWindowMask);
 }
 
 void
@@ -43,8 +44,8 @@ arrange(void *aux)
        else
                cols = rows;
 
-       gw = (sw - 1)  / cols;
-       gh = (sh - bh - 1) / rows;
+       gw = (sw - 2 * c->border)  / cols;
+       gh = (sh - bh - 2 * c->border) / rows;
 
        for(i = j = 0, c = clients; c; c = c->next) {
                c->x = i * gw;
@@ -57,6 +58,7 @@ arrange(void *aux)
                        i = 0;
                }
        }
+       discard_events(EnterWindowMask);
 }
 
 void
@@ -161,6 +163,10 @@ update_size(Client *c)
        }
        else
                c->minw = c->minh = 0;
+       if(c->flags & PWinGravity)
+               c->grav = size.win_gravity;
+       else
+               c->grav = NorthWestGravity;
 }
 
 void
@@ -213,6 +219,7 @@ manage(Window w, XWindowAttributes *wa)
        c->tw = c->w = wa->width;
        c->h = wa->height;
        c->th = bh;
+       c->border = 1;
        update_size(c);
        XSetWindowBorderWidth(dpy, c->win, 1);
        XSetWindowBorder(dpy, c->win, brush.border);
@@ -246,6 +253,61 @@ manage(Window w, XWindowAttributes *wa)
        focus(c);
 }
 
+void
+gravitate(Client *c, Bool invert)
+{
+       int dx = 0, dy = 0;
+
+       switch(c->grav) {
+       case StaticGravity:
+       case NorthWestGravity:
+       case NorthGravity:
+       case NorthEastGravity:
+               dy = c->border;
+               break;
+       case EastGravity:
+       case CenterGravity:
+       case WestGravity:
+               dy = -(c->h / 2) + c->border;
+               break;
+       case SouthEastGravity:
+       case SouthGravity:
+       case SouthWestGravity:
+               dy = -c->h;
+               break;
+       default:
+               break;
+       }
+
+       switch (c->grav) {
+       case StaticGravity:
+       case NorthWestGravity:
+       case WestGravity:
+       case SouthWestGravity:
+               dx = c->border;
+               break;
+       case NorthGravity:
+       case CenterGravity:
+       case SouthGravity:
+               dx = -(c->w / 2) + c->border;
+               break;
+       case NorthEastGravity:
+       case EastGravity:
+       case SouthEastGravity:
+               dx = -(c->w + c->border);
+               break;
+       default:
+               break;
+       }
+
+       if(invert) {
+               dx = -dx;
+               dy = -dy;
+       }
+       c->x += dx;
+       c->y += dy;
+}
+
 void
 resize(Client *c)
 {
@@ -260,7 +322,7 @@ resize(Client *c)
        e.y = c->y;
        e.width = c->w;
        e.height = c->h;
-       e.border_width = 0;
+       e.border_width = c->border;
        e.above = None;
        e.override_redirect = False;
        XSendEvent(dpy, c->win, False, StructureNotifyMask, (XEvent *)&e);
diff --git a/event.c b/event.c
index 1db3d96517e3f52663fdc8ac4e75222fcfdbb36c..93007dfc4607b5c3179457f0aea1de878a21cfda 100644 (file)
--- a/event.c
+++ b/event.c
@@ -77,6 +77,7 @@ configurerequest(XEvent *e)
 
        ev->value_mask &= ~CWSibling;
        if((c = getclient(ev->window))) {
+               gravitate(c, True);
                if(ev->value_mask & CWX)
                        c->x = ev->x;
                if(ev->value_mask & CWY)
@@ -85,6 +86,9 @@ configurerequest(XEvent *e)
                        c->w = ev->width;
                if(ev->value_mask & CWHeight)
                        c->h = ev->height;
+               if(ev->value_mask & CWBorderWidth)
+                       c->border = ev->border_width;
+               gravitate(c, False);
        }
 
        wc.x = ev->x;
diff --git a/kb.c b/kb.c
index 76c8be1291a5f55b14707fe699b29f9e785e1e62..ad7c71753bff7ee074418db8f37686dd53bd3e54 100644 (file)
--- a/kb.c
+++ b/kb.c
@@ -8,7 +8,7 @@
 #include <X11/keysym.h>
 
 static const char *term[] = { 
-       "xterm", "-bg", "black", "-fg", "white", "-fn",
+       "aterm", "-tr", "+sb", "-bg", "black", "-fg", "white", "-fn",
        "-*-terminus-medium-*-*-*-13-*-*-*-*-*-iso10646-*", 0 
 };
 
diff --git a/wm.h b/wm.h
index 3d9b63c7cd52beb253ec941ff7838979f6ca55fe..ee89f5b43237594c053f790af7ffe87a07029874 100644 (file)
--- a/wm.h
+++ b/wm.h
@@ -27,6 +27,8 @@ struct Client {
        int x, y, w, h;
        int tx, ty, tw, th;
        int basew, baseh, incw, inch, maxw, maxh, minw, minh;
+       int grav;
+       unsigned int border;
        long flags; 
        Window win;
        Window trans;
@@ -73,7 +75,8 @@ extern void lower(Client *c);
 extern void kill(void *aux);
 extern void sel(void *aux);
 extern void max(void *aux);
-extern void arrange();
+extern void arrange(void *aux);
+extern void gravitate(Client *c, Bool invert);
 
 /* event.c */
 extern void discard_events(long even_mask);