aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnselm R Garbe <anselm@garbe.us>2010-04-01 21:31:09 +0100
committerAnselm R Garbe <anselm@garbe.us>2010-04-01 21:31:09 +0100
commit3472085f59123384fa99252c195fee31160a7764 (patch)
tree2add56520b134be688cfc18610df6eeba72b166e
parent7ffe51981607c72abc969b23e79a1a46f6e2e422 (diff)
commited Connor's sanity patch
-rw-r--r--dmenu.c83
1 files changed, 32 insertions, 51 deletions
diff --git a/dmenu.c b/dmenu.c
index f6552aa..97014cc 100644
--- a/dmenu.c
+++ b/dmenu.c
@@ -118,18 +118,14 @@ calcoffsetsh(void) {
118 return; 118 return;
119 w = promptw + cmdw + 2 * spaceitem; 119 w = promptw + cmdw + 2 * spaceitem;
120 for(next = curr; next; next=next->right) { 120 for(next = curr; next; next=next->right) {
121 tw = textw(next->text); 121 tw = MIN(textw(next->text), mw / 3);
122 if(tw > mw / 3)
123 tw = mw / 3;
124 w += tw; 122 w += tw;
125 if(w > mw) 123 if(w > mw)
126 break; 124 break;
127 } 125 }
128 w = promptw + cmdw + 2 * spaceitem; 126 w = promptw + cmdw + 2 * spaceitem;
129 for(prev = curr; prev && prev->left; prev=prev->left) { 127 for(prev = curr; prev && prev->left; prev=prev->left) {
130 tw = textw(prev->left->text); 128 tw = MIN(textw(prev->left->text), mw / 3);
131 if(tw > mw / 3)
132 tw = mw / 3;
133 w += tw; 129 w += tw;
134 if(w > mw) 130 if(w > mw)
135 break; 131 break;
@@ -138,20 +134,20 @@ calcoffsetsh(void) {
138 134
139void 135void
140calcoffsetsv(void) { 136calcoffsetsv(void) {
141 static unsigned int w; 137 static unsigned int h;
142 138
143 if(!curr) 139 if(!curr)
144 return; 140 return;
145 w = (dc.font.height + 2) * (lines + 1); 141 h = (dc.font.height + 2) * (lines + 1);
146 for(next = curr; next; next=next->right) { 142 for(next = curr; next; next=next->right) {
147 w -= dc.font.height + 2; 143 h -= dc.font.height + 2;
148 if(w <= 0) 144 if(h <= 0)
149 break; 145 break;
150 } 146 }
151 w = (dc.font.height + 2) * (lines + 1); 147 h = (dc.font.height + 2) * (lines + 1);
152 for(prev = curr; prev && prev->left; prev=prev->left) { 148 for(prev = curr; prev && prev->left; prev=prev->left) {
153 w -= dc.font.height + 2; 149 h -= dc.font.height + 2;
154 if(w <= 0) 150 if(h <= 0)
155 break; 151 break;
156 } 152 }
157} 153}
@@ -352,10 +348,8 @@ initfont(const char *fontstr) {
352 font_extents = XExtentsOfFontSet(dc.font.set); 348 font_extents = XExtentsOfFontSet(dc.font.set);
353 n = XFontsOfFontSet(dc.font.set, &xfonts, &font_names); 349 n = XFontsOfFontSet(dc.font.set, &xfonts, &font_names);
354 for(i = 0, dc.font.ascent = 0, dc.font.descent = 0; i < n; i++) { 350 for(i = 0, dc.font.ascent = 0, dc.font.descent = 0; i < n; i++) {
355 if(dc.font.ascent < (*xfonts)->ascent) 351 dc.font.ascent = MAX(dc.font.ascent, (*xfonts)->ascent);
356 dc.font.ascent = (*xfonts)->ascent; 352 dc.font.descent = MAX(dc.font.descent, (*xfonts)->descent);
357 if(dc.font.descent < (*xfonts)->descent)
358 dc.font.descent = (*xfonts)->descent;
359 xfonts++; 353 xfonts++;
360 } 354 }
361 } 355 }
@@ -396,16 +390,16 @@ kpress(XKeyEvent * e) {
396 return; 390 return;
397 case XK_a: 391 case XK_a:
398 case XK_A: 392 case XK_A:
399 cursor = 0; 393 ksym = XK_Home;
400 break;
401 case XK_e:
402 case XK_E:
403 cursor = strlen(text);
404 break; 394 break;
405 case XK_c: 395 case XK_c:
406 case XK_C: 396 case XK_C:
407 ksym = XK_Escape; 397 ksym = XK_Escape;
408 break; 398 break;
399 case XK_e:
400 case XK_E:
401 ksym = XK_End;
402 break;
409 case XK_h: 403 case XK_h:
410 case XK_H: 404 case XK_H:
411 ksym = XK_BackSpace; 405 ksym = XK_BackSpace;
@@ -429,7 +423,7 @@ kpress(XKeyEvent * e) {
429 i = cursor; 423 i = cursor;
430 while(i-- > 0 && text[i] == ' '); 424 while(i-- > 0 && text[i] == ' ');
431 while(i-- > 0 && text[i] != ' '); 425 while(i-- > 0 && text[i] != ' ');
432 memmove(text + i + 1, text + cursor, sizeof text - cursor); 426 memmove(text + i + 1, text + cursor, sizeof text - cursor + 1);
433 cursor = i + 1; 427 cursor = i + 1;
434 match(text); 428 match(text);
435 } 429 }
@@ -460,12 +454,12 @@ kpress(XKeyEvent * e) {
460 case XK_p: 454 case XK_p:
461 { 455 {
462 FILE *fp; 456 FILE *fp;
463 char *c; 457 char *s;
464 if(!(fp = (FILE*)popen("sselp", "r"))) 458 if(!(fp = (FILE*)popen("sselp", "r")))
465 eprint("dmenu: Could not popen sselp\n"); 459 eprint("dmenu: Could not popen sselp\n");
466 c = fgets(buf, sizeof buf, fp); 460 s = fgets(buf, sizeof buf, fp);
467 pclose(fp); 461 pclose(fp);
468 if(c == NULL) 462 if(s == NULL)
469 return; 463 return;
470 } 464 }
471 num = strlen(buf); 465 num = strlen(buf);
@@ -621,32 +615,25 @@ match(char *pattern) {
621 615
622void 616void
623readstdin(void) { 617readstdin(void) {
624 char *p, buf[1024]; 618 char *p, buf[sizeof text];
625 unsigned int len = 0, blen = 0, max = 0; 619 unsigned int len = 0, max = 0;
626 Item *i, *new; 620 Item *i, *new;
627 621
628 i = 0, p = NULL; 622 i = NULL;
629 while(fgets(buf, sizeof buf, stdin)) { 623 while(fgets(buf, sizeof buf, stdin)) {
630 len += (blen = strlen(buf)); 624 len = strlen(buf);
631 if(!(p = realloc(p, len))) { 625 if(buf[len-1] == '\n')
632 eprint("fatal: could not realloc() %u bytes\n", len); 626 buf[--len] = '\0';
633 return; 627 if(!(p = strdup(buf)))
634 } 628 eprint("fatal: could not strdup() %u bytes\n", len);
635 memcpy (p + len - blen, buf, blen);
636 if (p[len - 1] == '\n')
637 p[len - 1] = 0;
638 else if (!feof(stdin))
639 continue;
640 if(max < len) { 629 if(max < len) {
641 maxname = p; 630 maxname = p;
642 max = len; 631 max = len;
643 } 632 }
644 len = 0;
645 if(!(new = (Item *)malloc(sizeof(Item)))) 633 if(!(new = (Item *)malloc(sizeof(Item))))
646 eprint("fatal: could not malloc() %u bytes\n", sizeof(Item)); 634 eprint("fatal: could not malloc() %u bytes\n", sizeof(Item));
647 new->next = new->left = new->right = NULL; 635 new->next = new->left = new->right = NULL;
648 new->text = p; 636 new->text = p;
649 p = NULL;
650 if(!i) 637 if(!i)
651 allitems = new; 638 allitems = new;
652 else 639 else
@@ -812,8 +799,8 @@ main(int argc, char *argv[]) {
812 else if(!strcmp(argv[i], "-v")) 799 else if(!strcmp(argv[i], "-v"))
813 eprint("dmenu-"VERSION", © 2006-2010 dmenu engineers, see LICENSE for details\n"); 800 eprint("dmenu-"VERSION", © 2006-2010 dmenu engineers, see LICENSE for details\n");
814 else 801 else
815 eprint("usage: dmenu [-i] [-b] [-l <lines>] [-fn <font>] [-nb <color>] [-nf <color>]\n" 802 eprint("usage: dmenu [-i] [-b] [-e <xid>] [-l <lines>] [-fn <font>] [-nb <color>]\n"
816 " [-p <prompt>] [-sb <color>] [-sf <color>] [-v]\n"); 803 " [-nf <color>] [-p <prompt>] [-sb <color>] [-sf <color>] [-v]\n");
817 if(!setlocale(LC_CTYPE, "") || !XSupportsLocale()) 804 if(!setlocale(LC_CTYPE, "") || !XSupportsLocale())
818 fprintf(stderr, "warning: no locale support\n"); 805 fprintf(stderr, "warning: no locale support\n");
819 if(!(dpy = XOpenDisplay(NULL))) 806 if(!(dpy = XOpenDisplay(NULL)))
@@ -822,14 +809,8 @@ main(int argc, char *argv[]) {
822 if(!root) 809 if(!root)
823 root = RootWindow(dpy, screen); 810 root = RootWindow(dpy, screen);
824 811
825 if(isatty(STDIN_FILENO)) { 812 readstdin();
826 readstdin(); 813 running = grabkeyboard();
827 running = grabkeyboard();
828 }
829 else { /* prevent keypress loss */
830 running = grabkeyboard();
831 readstdin();
832 }
833 814
834 setup(topbar); 815 setup(topbar);
835 drawmenu(); 816 drawmenu();