[CONTACT]

[ABOUT]

[POLICY]

git clone dmenu dmenu Log gph

Found at: gopher.r-36.net:70/scm/dmenu/commit/7ffe51981607c72abc969b23e79a1a46f6e2e422.gph

tapply nibble patch removing per-item length limit - dmenu - Dmenu fork with xft fonts.

git clone git://r-36.net/dmenu

Log

Files

Refs

README

LICENSE

---

commit 7ffe51981607c72abc969b23e79a1a46f6e2e422

parent 29686bd1b8513ba7512ab089cfdbc7df44986409

Author: pancake

Date:   Thu,  1 Apr 2010 19:30:21 +0200
apply nibble patch removing per-item length limit
Diffstat:
  dmenu.c                             |      21 ++++++++++++++-------
1 file changed, 14 insertions(+), 7 deletions(-)
---

diff --git a/dmenu.c b/dmenu.c

t@@ -622,24 +622,31 @@ match(char *pattern) {
 void
 readstdin(void) {
         char *p, buf[1024];
-        unsigned int len = 0, max = 0;
+        unsigned int len = 0, blen = 0, max = 0;
         Item *i, *new;
-        i = NULL;
+        i = 0, p = NULL;
         while(fgets(buf, sizeof buf, stdin)) {
-                len = strlen(buf);
-                if(buf[len-1] == '\n')
-                        buf[--len] = '\0';
-                if(!(p = strdup(buf)))
-                        eprint("fatal: could not strdup() %u bytes\n", len);
+                len += (blen = strlen(buf));
+                if(!(p = realloc(p, len))) {
+                        eprint("fatal: could not realloc() %u bytes\n", len);
+                        return;
+                }
+                memcpy (p + len - blen, buf, blen);
+                if (p[len - 1] == '\n')
+                        p[len - 1] = 0;
+                else if (!feof(stdin))
+                        continue;
                 if(max < len) {
                         maxname = p;
                         max = len;
                 }
+                len = 0;
                 if(!(new = (Item *)malloc(sizeof(Item))))
                         eprint("fatal: could not malloc() %u bytes\n", sizeof(Item));
                 new->next = new->left = new->right = NULL;
                 new->text = p;
+                p = NULL;
                 if(!i)
                         allitems = new;
                 else
.


AD: