tfixed string cutting - dmenu - Dmenu fork with xft fonts.
 (HTM) git clone git://r-36.net/dmenu
 (DIR) Log
 (DIR) Files
 (DIR) Refs
 (DIR) README
 (DIR) LICENSE
       ---
 (DIR) commit 0e21ef5f3701cafb9936b5fcbfc204bc477cb215
 (DIR) parent 2f3068fb77aed6c5128b7df1571bee1edaa35d92
 (HTM) Author: Anselm R.Garbe <arg@10ksloc.org>
       Date:   Mon, 14 Aug 2006 08:52:28 +0200
       
       fixed string cutting
       
       Diffstat:
         draw.c                              |      12 ++++++++++--
       
       1 file changed, 10 insertions(+), 2 deletions(-)
       ---
 (DIR) diff --git a/draw.c b/draw.c
       t@@ -28,7 +28,7 @@ drawtext(const char *text, Bool invert, Bool border)
        {
                int x, y, w, h;
                static char buf[256];
       -        unsigned int len;
       +        unsigned int len, olen;
                XGCValues gcv;
                XPoint points[5];
                XRectangle r = { dc.x, dc.y, dc.w, dc.h };
       t@@ -56,7 +56,7 @@ drawtext(const char *text, Bool invert, Bool border)
                if(!text)
                        return;
        
       -        len = strlen(text);
       +        olen = len = strlen(text);
                if(len >= sizeof(buf))
                        len = sizeof(buf) - 1;
                memcpy(buf, text, len);
       t@@ -69,6 +69,14 @@ drawtext(const char *text, Bool invert, Bool border)
                /* shorten text if necessary */
                while(len && (w = textnw(buf, len)) > dc.w - h)
                        buf[--len] = 0;
       +        if(len < olen) {
       +                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);
       +        }
        
                if(w > dc.w)
                        return; /* too long */