diff options
author | Anselm R. Garbe <arg@suckless.org> | 2007-02-20 13:54:00 +0100 |
---|---|---|
committer | Anselm R. Garbe <arg@suckless.org> | 2007-02-20 13:54:00 +0100 |
commit | a1913a6af7c9cd6de18e15e989050690fdaa6600 (patch) | |
tree | 2a6269418606217571e026efab125866ef2a5376 /main.c | |
parent | 66b2e8379f0b851d0535a50321e22b58fdaa247d (diff) | |
download | dmenu-a1913a6af7c9cd6de18e15e989050690fdaa6600.tar.gz dmenu-a1913a6af7c9cd6de18e15e989050690fdaa6600.tar.bz2 dmenu-a1913a6af7c9cd6de18e15e989050690fdaa6600.zip |
readded draw.c again (except getcolor and setfont)
Diffstat (limited to 'main.c')
-rw-r--r-- | main.c | 64 |
1 files changed, 0 insertions, 64 deletions
@@ -3,7 +3,6 @@ * See LICENSE file for license details. */ #include "dmenu.h" - #include <ctype.h> #include <locale.h> #include <stdlib.h> @@ -42,22 +41,6 @@ static Item *curr = NULL; static Window root; static Window win; -static unsigned int -textnw(const char *text, unsigned int len) { - XRectangle r; - - if(dc.font.set) { - XmbTextExtents(dc.font.set, text, len, NULL, &r); - return r.width; - } - return XTextWidth(dc.font.xfont, text, len); -} - -static unsigned int -textw(const char *text) { - return textnw(text, strlen(text)) + dc.font.height; -} - static void calcoffsets(void) { unsigned int tw, w; @@ -85,53 +68,6 @@ calcoffsets(void) { } static void -drawtext(const char *text, unsigned long col[ColLast]) { - int x, y, w, h; - static char buf[256]; - unsigned int len, olen; - XGCValues gcv; - XRectangle r = { dc.x, dc.y, dc.w, dc.h }; - - XSetForeground(dpy, dc.gc, col[ColBG]); - XFillRectangles(dpy, dc.drawable, dc.gc, &r, 1); - if(!text) - return; - w = 0; - olen = len = strlen(text); - if(len >= sizeof buf) - len = sizeof buf - 1; - memcpy(buf, text, len); - buf[len] = 0; - h = dc.font.ascent + dc.font.descent; - y = dc.y + (dc.h / 2) - (h / 2) + dc.font.ascent; - x = dc.x + (h / 2); - /* shorten text if necessary */ - 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) - buf[len - 3] = '.'; - } - if(w > dc.w) - return; /* too long */ - gcv.foreground = col[ColFG]; - if(dc.font.set) { - XChangeGC(dpy, dc.gc, GCForeground, &gcv); - 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 | GCFont, &gcv); - XDrawString(dpy, dc.drawable, dc.gc, x, y, buf, len); - } -} - -static void drawmenu(void) { Item *i; |