new stuff, fixed several issues
authorAnselm R. Garbe <garbeam@wmii.de>
Wed, 12 Jul 2006 15:50:31 +0000 (17:50 +0200)
committerAnselm R. Garbe <garbeam@wmii.de>
Wed, 12 Jul 2006 15:50:31 +0000 (17:50 +0200)
client.c
config.mk
draw.c
event.c
util.c
wm.c

index e9b83fe8d3ed3e4dc5c40ba033b8a5fe41e075f7..95ec3a65a5fe3f6f0c3cebf1398d72269ce80684 100644 (file)
--- a/client.c
+++ b/client.c
@@ -44,8 +44,8 @@ arrange(void *aux)
        else
                cols = rows;
 
-       gw = (sw - 2 * c->border)  / cols;
-       gh = (sh - bh - 2 * c->border) / rows;
+       gw = (sw - 2)  / cols;
+       gh = (sh - bh - 2) / rows;
 
        for(i = j = 0, c = clients; c; c = c->next) {
                c->x = i * gw;
index 0e5d372c0db5ee3924323ec6cb1f6a30fdef4b8b..41cb0708566adf18f3f1468f50657a9050097548 100644 (file)
--- a/config.mk
+++ b/config.mk
@@ -14,7 +14,7 @@ VERSION = 0.0
 LIBS = -L${PREFIX}/lib -L/usr/lib -lc -lm -L${X11LIB} -lX11
 
 # Linux/BSD
-CFLAGS = -g -Wall -I. -I${PREFIX}/include -I/usr/include -I${X11INC} \
+CFLAGS = -g -Wall -O2 -I. -I${PREFIX}/include -I/usr/include -I${X11INC} \
        -DVERSION=\"${VERSION}\"
 LDFLAGS = -g ${LIBS}
 
diff --git a/draw.c b/draw.c
index c148362e70ff683efb1a6b552cc4504eed901a9f..68ece01ab060b5fead315f1378932c462d8b07e4 100644 (file)
--- a/draw.c
+++ b/draw.c
@@ -39,6 +39,7 @@ draw(Display *dpy, Brush *b, Bool border, const char *text)
        XSetForeground(dpy, b->gc, b->bg);
        XFillRectangles(dpy, b->drawable, b->gc, &r, 1);
 
+       w = 0;
        if(border)
                drawborder(dpy, b);
 
diff --git a/event.c b/event.c
index 93007dfc4607b5c3179457f0aea1de878a21cfda..37196d1fdffa3d987787552339fd6ad011de063d 100644 (file)
--- a/event.c
+++ b/event.c
@@ -186,11 +186,11 @@ propertynotify(XEvent *e)
        if(ev->state == PropertyDelete)
                return; /* ignore */
 
-       if(ev->atom == wm_atom[WMProtocols]) {
-               c->proto = win_proto(c->win);
-               return;
-       }
        if((c = getclient(ev->window))) {
+               if(ev->atom == wm_atom[WMProtocols]) {
+                       c->proto = win_proto(c->win);
+                       return;
+               }
                switch (ev->atom) {
                        default: break;
                        case XA_WM_TRANSIENT_FOR:
diff --git a/util.c b/util.c
index 9da8f52b58cb01f5515758372c3f57023f405286..3f41b3c9e846c9ed4e51f2d2a115bc12d3521638 100644 (file)
--- a/util.c
+++ b/util.c
@@ -126,13 +126,14 @@ pipe_spawn(char *buf, unsigned int len, Display *dpy, char *argv[])
                perror(" failed");
        }
        else {
-               n = 0;
+               l = n = 0;
                close(pfd[1]);
-               while(l > n) {
+               while(n < len) {
                        if((l = read(pfd[0], buf + n, len - n)) < 1)
                                break;
                        n += l;
                }
+               while(l > n);
                close(pfd[0]);
                buf[n < len ? n : len - 1] = 0;
        }
diff --git a/wm.c b/wm.c
index 02b9a68a9de652bc2c8236b540cbfb0e4789fa24..ed40a8b4ed1c1d3832c2f21aaac22fcdfad82d41 100644 (file)
--- a/wm.c
+++ b/wm.c
@@ -95,13 +95,12 @@ win_property(Window w, Atom a, Atom t, long l, unsigned char **prop)
 int
 win_proto(Window w)
 {
-       Atom *protocols;
+       unsigned char *protocols;
        long res;
        int protos = 0;
        int i;
 
-       res = win_property(w, wm_atom[WMProtocols], XA_ATOM, 20L,
-                       ((unsigned char **) &protocols));
+       res = win_property(w, wm_atom[WMProtocols], XA_ATOM, 20L, &protocols);
        if(res <= 0) {
                return protos;
        }