Compare commits
13 Commits
Author | SHA1 | Date | |
---|---|---|---|
bbfd5391ac | |||
0e96ae6f48 | |||
989649b5a5 | |||
f8d2a29a20 | |||
3438af001a | |||
201b056e39 | |||
3dcdbe2a57 | |||
5336608a86 | |||
d398a2e318 | |||
2829009138 | |||
cae2fbdf38 | |||
225cd764c3 | |||
279966a16f |
2
.hgtags
2
.hgtags
@ -14,3 +14,5 @@ bee7fe6d1189174d0204ca3195b83cdc1bb4f82e 1.2
|
|||||||
df3fbb050004c544d14e43c36f6a94cca6ed4a69 1.4
|
df3fbb050004c544d14e43c36f6a94cca6ed4a69 1.4
|
||||||
e071fb045bd9e8574947acff7196360bc0270e68 1.5
|
e071fb045bd9e8574947acff7196360bc0270e68 1.5
|
||||||
dcc5427f99f51a978386a0dd770467cd911ac84b 1.6
|
dcc5427f99f51a978386a0dd770467cd911ac84b 1.6
|
||||||
|
58dbef4aef3d45c7a3da6945e53c9667c0f02d5b 1.7
|
||||||
|
3696d77aaf02f5d15728dde3b9e35abcaf291496 1.7.1
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
# dmenu version
|
# dmenu version
|
||||||
VERSION = 1.7
|
VERSION = 1.8
|
||||||
|
|
||||||
# Customize below to fit your system
|
# Customize below to fit your system
|
||||||
|
|
||||||
@ -20,6 +20,11 @@ LDFLAGS = ${LIBS}
|
|||||||
#CFLAGS = -g -Wall -O2 ${INCS} -DVERSION=\"${VERSION}\"
|
#CFLAGS = -g -Wall -O2 ${INCS} -DVERSION=\"${VERSION}\"
|
||||||
#LDFLAGS = -g ${LIBS}
|
#LDFLAGS = -g ${LIBS}
|
||||||
|
|
||||||
|
# Solaris
|
||||||
|
#CFLAGS = -fast ${INCS} -DVERSION=\"${VERSION}\"
|
||||||
|
#LDFLAGS = ${LIBS}
|
||||||
|
#CFLAGS += -xtarget=ultra
|
||||||
|
|
||||||
# compiler and linker
|
# compiler and linker
|
||||||
CC = cc
|
CC = cc
|
||||||
LD = ${CC}
|
LD = ${CC}
|
||||||
|
35
dmenu.1
35
dmenu.1
@ -3,12 +3,13 @@
|
|||||||
dmenu \- dynamic menu
|
dmenu \- dynamic menu
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B dmenu
|
.B dmenu
|
||||||
.RB [ \-font " <name>"]
|
.RB [ \-b ]
|
||||||
.RB [ \-normbg " <color>"]
|
.RB [ \-fn " <font>"]
|
||||||
.RB [ \-normfg " <color>"]
|
.RB [ \-nb " <color>"]
|
||||||
.RB [ \-selbg " <color>"]
|
.RB [ \-nf " <color>"]
|
||||||
.RB [ \-selfg " <color>"]
|
|
||||||
.RB [ \-p " <prompt>"]
|
.RB [ \-p " <prompt>"]
|
||||||
|
.RB [ \-sb " <color>"]
|
||||||
|
.RB [ \-sf " <color>"]
|
||||||
.RB [ \-t " <seconds>"]
|
.RB [ \-t " <seconds>"]
|
||||||
.RB [ \-v ]
|
.RB [ \-v ]
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
@ -19,24 +20,27 @@ It manages huge amounts (up to 10.000 and more) of user defined menu items
|
|||||||
efficiently.
|
efficiently.
|
||||||
.SS Options
|
.SS Options
|
||||||
.TP
|
.TP
|
||||||
.B \-font <name>
|
.B \-b
|
||||||
|
makes dmenu appear at the screen bottom (by default it appears at the screen top).
|
||||||
|
.TP
|
||||||
|
.B \-fn <font>
|
||||||
defines the font.
|
defines the font.
|
||||||
.TP
|
.TP
|
||||||
.B \-normbg <color>
|
.B \-nb <color>
|
||||||
defines the normal background color (#RGB, #RRGGBB, and color names are supported).
|
defines the normal background color (#RGB, #RRGGBB, and color names are supported).
|
||||||
.TP
|
.TP
|
||||||
.B \-normfg <color>
|
.B \-nf <color>
|
||||||
defines the normal foreground color (#RGB, #RRGGBB, and color names are supported).
|
defines the normal foreground color (#RGB, #RRGGBB, and color names are supported).
|
||||||
.TP
|
.TP
|
||||||
.B \-selbg <color>
|
|
||||||
defines the selected background color (#RGB, #RRGGBB, and color names are supported).
|
|
||||||
.TP
|
|
||||||
.B \-selfg <color>
|
|
||||||
defines the selected foreground color (#RGB, #RRGGBB, and color names are supported).
|
|
||||||
.TP
|
|
||||||
.B \-p <prompt>
|
.B \-p <prompt>
|
||||||
defines a prompt to be displayed before the input area.
|
defines a prompt to be displayed before the input area.
|
||||||
.TP
|
.TP
|
||||||
|
.B \-sb <color>
|
||||||
|
defines the selected background color (#RGB, #RRGGBB, and color names are supported).
|
||||||
|
.TP
|
||||||
|
.B \-sf <color>
|
||||||
|
defines the selected foreground color (#RGB, #RRGGBB, and color names are supported).
|
||||||
|
.TP
|
||||||
.B \-t <seconds>
|
.B \-t <seconds>
|
||||||
defines the seconds to wait for standard input, before exiting (default is 3).
|
defines the seconds to wait for standard input, before exiting (default is 3).
|
||||||
.TP
|
.TP
|
||||||
@ -87,4 +91,5 @@ Remove enough characters from the input field to change its filtering effect.
|
|||||||
.B Control-u
|
.B Control-u
|
||||||
Remove all characters from the input field.
|
Remove all characters from the input field.
|
||||||
.SH SEE ALSO
|
.SH SEE ALSO
|
||||||
.BR dwm (1)
|
.BR dwm (1),
|
||||||
|
.BR wmii (1) .
|
||||||
|
72
main.c
72
main.c
@ -178,6 +178,29 @@ kpress(XKeyEvent * e) {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if(e->state & Mod1Mask) {
|
||||||
|
switch(ksym) {
|
||||||
|
default: return;
|
||||||
|
case XK_h:
|
||||||
|
ksym = XK_Left;
|
||||||
|
break;
|
||||||
|
case XK_l:
|
||||||
|
ksym = XK_Right;
|
||||||
|
break;
|
||||||
|
case XK_j:
|
||||||
|
ksym = XK_Next;
|
||||||
|
break;
|
||||||
|
case XK_k:
|
||||||
|
ksym = XK_Prior;
|
||||||
|
break;
|
||||||
|
case XK_g:
|
||||||
|
ksym = XK_Home;
|
||||||
|
break;
|
||||||
|
case XK_G:
|
||||||
|
ksym = XK_End;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
switch(ksym) {
|
switch(ksym) {
|
||||||
default:
|
default:
|
||||||
if(num && !iscntrl((int) buf[0])) {
|
if(num && !iscntrl((int) buf[0])) {
|
||||||
@ -200,11 +223,13 @@ kpress(XKeyEvent * e) {
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case XK_End:
|
case XK_End:
|
||||||
|
if(!item)
|
||||||
|
return;
|
||||||
while(next) {
|
while(next) {
|
||||||
sel = curr = next;
|
sel = curr = next;
|
||||||
calcoffsets();
|
calcoffsets();
|
||||||
}
|
}
|
||||||
while(sel->right)
|
while(sel && sel->right)
|
||||||
sel = sel->right;
|
sel = sel->right;
|
||||||
break;
|
break;
|
||||||
case XK_Escape:
|
case XK_Escape:
|
||||||
@ -212,6 +237,8 @@ kpress(XKeyEvent * e) {
|
|||||||
running = False;
|
running = False;
|
||||||
break;
|
break;
|
||||||
case XK_Home:
|
case XK_Home:
|
||||||
|
if(!item)
|
||||||
|
return;
|
||||||
sel = curr = item;
|
sel = curr = item;
|
||||||
calcoffsets();
|
calcoffsets();
|
||||||
break;
|
break;
|
||||||
@ -225,16 +252,16 @@ kpress(XKeyEvent * e) {
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case XK_Next:
|
case XK_Next:
|
||||||
if(next) {
|
if(!next)
|
||||||
sel = curr = next;
|
return;
|
||||||
calcoffsets();
|
sel = curr = next;
|
||||||
}
|
calcoffsets();
|
||||||
break;
|
break;
|
||||||
case XK_Prior:
|
case XK_Prior:
|
||||||
if(prev) {
|
if(!prev)
|
||||||
sel = curr = prev;
|
return;
|
||||||
calcoffsets();
|
sel = curr = prev;
|
||||||
}
|
calcoffsets();
|
||||||
break;
|
break;
|
||||||
case XK_Return:
|
case XK_Return:
|
||||||
if((e->state & ShiftMask) && text)
|
if((e->state & ShiftMask) && text)
|
||||||
@ -303,6 +330,7 @@ DC dc = {0};
|
|||||||
|
|
||||||
int
|
int
|
||||||
main(int argc, char *argv[]) {
|
main(int argc, char *argv[]) {
|
||||||
|
Bool bottom = False;
|
||||||
char *font = FONT;
|
char *font = FONT;
|
||||||
char *maxname;
|
char *maxname;
|
||||||
char *normbg = NORMBGCOLOR;
|
char *normbg = NORMBGCOLOR;
|
||||||
@ -320,24 +348,27 @@ main(int argc, char *argv[]) {
|
|||||||
timeout.tv_sec = 3;
|
timeout.tv_sec = 3;
|
||||||
/* command line args */
|
/* command line args */
|
||||||
for(i = 1; i < argc; i++)
|
for(i = 1; i < argc; i++)
|
||||||
if(!strncmp(argv[i], "-font", 6)) {
|
if(!strncmp(argv[i], "-b", 3)) {
|
||||||
|
bottom = True;
|
||||||
|
}
|
||||||
|
else if(!strncmp(argv[i], "-fn", 4)) {
|
||||||
if(++i < argc) font = argv[i];
|
if(++i < argc) font = argv[i];
|
||||||
}
|
}
|
||||||
else if(!strncmp(argv[i], "-normbg", 8)) {
|
else if(!strncmp(argv[i], "-nb", 4)) {
|
||||||
if(++i < argc) normbg = argv[i];
|
if(++i < argc) normbg = argv[i];
|
||||||
}
|
}
|
||||||
else if(!strncmp(argv[i], "-normfg", 8)) {
|
else if(!strncmp(argv[i], "-nf", 4)) {
|
||||||
if(++i < argc) normfg = argv[i];
|
if(++i < argc) normfg = argv[i];
|
||||||
}
|
}
|
||||||
else if(!strncmp(argv[i], "-selbg", 7)) {
|
|
||||||
if(++i < argc) selbg = argv[i];
|
|
||||||
}
|
|
||||||
else if(!strncmp(argv[i], "-selfg", 7)) {
|
|
||||||
if(++i < argc) selfg = argv[i];
|
|
||||||
}
|
|
||||||
else if(!strncmp(argv[i], "-p", 3)) {
|
else if(!strncmp(argv[i], "-p", 3)) {
|
||||||
if(++i < argc) prompt = argv[i];
|
if(++i < argc) prompt = argv[i];
|
||||||
}
|
}
|
||||||
|
else if(!strncmp(argv[i], "-sb", 4)) {
|
||||||
|
if(++i < argc) selbg = argv[i];
|
||||||
|
}
|
||||||
|
else if(!strncmp(argv[i], "-sf", 4)) {
|
||||||
|
if(++i < argc) selfg = argv[i];
|
||||||
|
}
|
||||||
else if(!strncmp(argv[i], "-t", 3)) {
|
else if(!strncmp(argv[i], "-t", 3)) {
|
||||||
if(++i < argc) timeout.tv_sec = atoi(argv[i]);
|
if(++i < argc) timeout.tv_sec = atoi(argv[i]);
|
||||||
}
|
}
|
||||||
@ -346,7 +377,8 @@ main(int argc, char *argv[]) {
|
|||||||
exit(EXIT_SUCCESS);
|
exit(EXIT_SUCCESS);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
eprint("usage: dmenu [-font <name>] [-{norm,sel}{bg,fg} <color>] [-p <prompt>] [-t <seconds>] [-v]\n", stdout);
|
eprint("usage: dmenu [-b] [-fn <font>] [-nb <color>] [-nf <color>] [-p <prompt>]\n"
|
||||||
|
" [-sb <color>] [-sf <color>] [-t <seconds>] [-v]\n", stdout);
|
||||||
setlocale(LC_CTYPE, "");
|
setlocale(LC_CTYPE, "");
|
||||||
dpy = XOpenDisplay(0);
|
dpy = XOpenDisplay(0);
|
||||||
if(!dpy)
|
if(!dpy)
|
||||||
@ -380,6 +412,8 @@ main(int argc, char *argv[]) {
|
|||||||
mx = my = 0;
|
mx = my = 0;
|
||||||
mw = DisplayWidth(dpy, screen);
|
mw = DisplayWidth(dpy, screen);
|
||||||
mh = dc.font.height + 2;
|
mh = dc.font.height + 2;
|
||||||
|
if(bottom)
|
||||||
|
my += DisplayHeight(dpy, screen) - mh;
|
||||||
win = XCreateWindow(dpy, root, mx, my, mw, mh, 0,
|
win = XCreateWindow(dpy, root, mx, my, mw, mh, 0,
|
||||||
DefaultDepth(dpy, screen), CopyFromParent,
|
DefaultDepth(dpy, screen), CopyFromParent,
|
||||||
DefaultVisual(dpy, screen),
|
DefaultVisual(dpy, screen),
|
||||||
|
Reference in New Issue
Block a user