diff options
author | Connor Lane Smith <cls@lubutu.com> | 2011-05-08 15:15:24 +0100 |
---|---|---|
committer | Connor Lane Smith <cls@lubutu.com> | 2011-05-08 15:15:24 +0100 |
commit | e0e6b071c63f960c398b43b2fbf0dec66a9b3ab6 (patch) | |
tree | 5a1d4affa4cfc85402f9e2c8fcbdbbecffb6b259 | |
parent | cd3b4915c3358b93f8dbff531bff82c0cd833c0b (diff) |
fast grab patch (thanks Rob)
-rw-r--r-- | dmenu.1 | 22 | ||||
-rw-r--r-- | dmenu.c | 18 |
2 files changed, 27 insertions, 13 deletions
@@ -4,6 +4,7 @@ dmenu \- dynamic menu | |||
4 | .SH SYNOPSIS | 4 | .SH SYNOPSIS |
5 | .B dmenu | 5 | .B dmenu |
6 | .RB [ \-b ] | 6 | .RB [ \-b ] |
7 | .RB [ \-f ] | ||
7 | .RB [ \-i ] | 8 | .RB [ \-i ] |
8 | .RB [ \-l | 9 | .RB [ \-l |
9 | .IR lines ] | 10 | .IR lines ] |
@@ -32,9 +33,9 @@ is a dynamic menu for X, originally designed for | |||
32 | .BR dwm (1). | 33 | .BR dwm (1). |
33 | It manages huge numbers of user-defined menu items efficiently. | 34 | It manages huge numbers of user-defined menu items efficiently. |
34 | .P | 35 | .P |
35 | dmenu reads a list of newline-separated items from standard input and creates a | 36 | dmenu reads a list of newline-separated items from stdin and creates a menu. |
36 | menu. When the user selects an item or enters any text and presses Return, | 37 | When the user selects an item or enters any text and presses Return, their |
37 | their choice is printed to standard output and dmenu terminates. | 38 | choice is printed to stdout and dmenu terminates. |
38 | .P | 39 | .P |
39 | .B dmenu_run | 40 | .B dmenu_run |
40 | is a dmenu script used by dwm which lists programs in the user's PATH and | 41 | is a dmenu script used by dwm which lists programs in the user's PATH and |
@@ -47,6 +48,10 @@ is a program used by dmenu_run to find and cache a list of executables. | |||
47 | .B \-b | 48 | .B \-b |
48 | dmenu appears at the bottom of the screen. | 49 | dmenu appears at the bottom of the screen. |
49 | .TP | 50 | .TP |
51 | .B \-f | ||
52 | dmenu grabs the keyboard before reading stdin. This is faster, but may lock up | ||
53 | X if stdin is from a terminal. | ||
54 | .TP | ||
50 | .B \-i | 55 | .B \-i |
51 | dmenu matches menu items case insensitively. | 56 | dmenu matches menu items case insensitively. |
52 | .TP | 57 | .TP |
@@ -66,7 +71,7 @@ defines the font or font set used. | |||
66 | defines the normal background color. | 71 | defines the normal background color. |
67 | .IR #RGB , | 72 | .IR #RGB , |
68 | .IR #RRGGBB , | 73 | .IR #RRGGBB , |
69 | and color names are supported. | 74 | and X color names are supported. |
70 | .TP | 75 | .TP |
71 | .BI \-nf " color" | 76 | .BI \-nf " color" |
72 | defines the normal foreground color. | 77 | defines the normal foreground color. |
@@ -78,7 +83,7 @@ defines the selected background color. | |||
78 | defines the selected foreground color. | 83 | defines the selected foreground color. |
79 | .TP | 84 | .TP |
80 | .B \-v | 85 | .B \-v |
81 | prints version information to standard output, then exits. | 86 | prints version information to stdout, then exits. |
82 | .SH USAGE | 87 | .SH USAGE |
83 | dmenu is completely controlled by the keyboard. Besides standard Unix line | 88 | dmenu is completely controlled by the keyboard. Besides standard Unix line |
84 | editing and item selection (Up/Down/Left/Right, PageUp/PageDown, Home/End), the | 89 | editing and item selection (Up/Down/Left/Right, PageUp/PageDown, Home/End), the |
@@ -88,12 +93,11 @@ following keys are recognized: | |||
88 | Copy the selected item to the input field. | 93 | Copy the selected item to the input field. |
89 | .TP | 94 | .TP |
90 | .B Return (Control\-j) | 95 | .B Return (Control\-j) |
91 | Confirm selection. Prints the selected item to standard output and exits, | 96 | Confirm selection. Prints the selected item to stdout and exits, returning |
92 | returning success. | 97 | success. |
93 | .TP | 98 | .TP |
94 | .B Shift\-Return (Control\-Shift\-j) | 99 | .B Shift\-Return (Control\-Shift\-j) |
95 | Confirm input. Prints the input text to standard output and exits, returning | 100 | Confirm input. Prints the input text to stdout and exits, returning success. |
96 | success. | ||
97 | .TP | 101 | .TP |
98 | .B Escape (Control\-c) | 102 | .B Escape (Control\-c) |
99 | Exit without selecting an item, returning failure. | 103 | Exit without selecting an item, returning failure. |
@@ -64,6 +64,7 @@ static int (*fstrncmp)(const char *, const char *, size_t) = strncmp; | |||
64 | 64 | ||
65 | int | 65 | int |
66 | main(int argc, char *argv[]) { | 66 | main(int argc, char *argv[]) { |
67 | Bool fast = False; | ||
67 | int i; | 68 | int i; |
68 | 69 | ||
69 | progname = "dmenu"; | 70 | progname = "dmenu"; |
@@ -77,6 +78,8 @@ main(int argc, char *argv[]) { | |||
77 | topbar = False; | 78 | topbar = False; |
78 | else if(!strcmp(argv[i], "-i")) | 79 | else if(!strcmp(argv[i], "-i")) |
79 | fstrncmp = strncasecmp; | 80 | fstrncmp = strncasecmp; |
81 | else if(!strcmp(argv[i], "-f")) | ||
82 | fast = True; | ||
80 | else if(i == argc-1) | 83 | else if(i == argc-1) |
81 | goto usage; | 84 | goto usage; |
82 | /* double flags */ | 85 | /* double flags */ |
@@ -101,13 +104,21 @@ main(int argc, char *argv[]) { | |||
101 | 104 | ||
102 | dc = initdc(); | 105 | dc = initdc(); |
103 | initfont(dc, font); | 106 | initfont(dc, font); |
104 | readstdin(); | 107 | |
105 | setup(); | 108 | if(fast) { |
109 | setup(); | ||
110 | readstdin(); | ||
111 | } | ||
112 | else { | ||
113 | readstdin(); | ||
114 | setup(); | ||
115 | } | ||
116 | match(); | ||
106 | run(); | 117 | run(); |
107 | return EXIT_FAILURE; | 118 | return EXIT_FAILURE; |
108 | 119 | ||
109 | usage: | 120 | usage: |
110 | fputs("usage: dmenu [-b] [-i] [-l lines] [-m monitor] [-p prompt] [-fn font]\n" | 121 | fputs("usage: dmenu [-b] [-f] [-i] [-l lines] [-m monitor] [-p prompt] [-fn font]\n" |
111 | " [-nb color] [-nf color] [-sb color] [-sf color] [-v]\n", stderr); | 122 | " [-nb color] [-nf color] [-sb color] [-sf color] [-v]\n", stderr); |
112 | return EXIT_FAILURE; | 123 | return EXIT_FAILURE; |
113 | } | 124 | } |
@@ -530,5 +541,4 @@ setup(void) { | |||
530 | inputw = MIN(inputw, mw/3); | 541 | inputw = MIN(inputw, mw/3); |
531 | promptw = prompt ? textw(dc, prompt) : 0; | 542 | promptw = prompt ? textw(dc, prompt) : 0; |
532 | XMapRaised(dc->dpy, win); | 543 | XMapRaised(dc->dpy, win); |
533 | match(); | ||
534 | } | 544 | } |