removed useless call
[dmenu.git] / draw.c
diff --git a/draw.c b/draw.c
index 066a0bf..ba1fafd 100644 (file)
--- a/draw.c
+++ b/draw.c
@@ -24,22 +24,20 @@ textnw(const char *text, unsigned int len)
 /* extern */
 
 void
-drawtext(const char *text, Bool invert, Bool border)
+drawtext(const char *text, unsigned int colidx, Bool border)
 {
        int x, y, w, h;
        static char buf[256];
        unsigned int len, olen;
-       XGCValues gcv;
        XPoint points[5];
        XRectangle r = { dc.x, dc.y, dc.w, dc.h };
 
-       XSetForeground(dpy, dc.gc, invert ? dc.fg : dc.bg);
+       XSetForeground(dpy, dc.gc, dc.bg[colidx]);
        XFillRectangles(dpy, dc.drawable, dc.gc, &r, 1);
 
        w = 0;
+       XSetForeground(dpy, dc.gc, dc.fg[colidx]);
        if(border) {
-               XSetLineAttributes(dpy, dc.gc, 1, LineSolid, CapButt, JoinMiter);
-               XSetForeground(dpy, dc.gc, dc.border);
                points[0].x = dc.x;
                points[0].y = dc.y;
                points[1].x = dc.w - 1;
@@ -70,28 +68,22 @@ drawtext(const char *text, Bool invert, Bool border)
        while(len && (w = textnw(buf, len)) > dc.w - h)
                buf[--len] = 0;
        if(len < olen) {
+               if(len > 1)
+                       buf[len - 1] = '.';
+               if(len > 2)
+                       buf[len - 2] = '.';
                if(len > 3)
-                       memcpy(buf + len - 4, "...\0", 4);
-               else if(len > 2)
-                       memcpy(buf + len - 3, "..\0", 3);
-               else if(len > 1)
-                       memcpy(buf + len - 2, ".\0", 2);
+                       buf[len - 3] = '.';
        }
 
        if(w > dc.w)
                return; /* too long */
 
-       gcv.foreground = invert ? dc.bg : dc.fg;
-       gcv.background = invert ? dc.fg : dc.bg;
-       if(dc.font.set) {
-               XChangeGC(dpy, dc.gc, GCForeground | GCBackground, &gcv);
-               XmbDrawImageString(dpy, dc.drawable, dc.font.set, dc.gc,
-                               x, y, buf, len);
-       }
+       if(dc.font.set)
+               XmbDrawString(dpy, dc.drawable, dc.font.set, dc.gc, x, y, buf, len);
        else {
-               gcv.font = dc.font.xfont->fid;
-               XChangeGC(dpy, dc.gc, GCForeground | GCBackground | GCFont, &gcv);
-               XDrawImageString(dpy, dc.drawable, dc.gc, x, y, buf, len);
+               XSetFont(dpy, dc.gc, dc.font.xfont->fid);
+               XDrawString(dpy, dc.drawable, dc.gc, x, y, buf, len);
        }
 }