Compare commits
8 Commits
Author | SHA1 | Date | |
---|---|---|---|
bbfd5391ac | |||
0e96ae6f48 | |||
989649b5a5 | |||
f8d2a29a20 | |||
3438af001a | |||
201b056e39 | |||
3dcdbe2a57 | |||
5336608a86 |
1
.hgtags
1
.hgtags
@ -15,3 +15,4 @@ df3fbb050004c544d14e43c36f6a94cca6ed4a69 1.4
|
||||
e071fb045bd9e8574947acff7196360bc0270e68 1.5
|
||||
dcc5427f99f51a978386a0dd770467cd911ac84b 1.6
|
||||
58dbef4aef3d45c7a3da6945e53c9667c0f02d5b 1.7
|
||||
3696d77aaf02f5d15728dde3b9e35abcaf291496 1.7.1
|
||||
|
@ -1,5 +1,5 @@
|
||||
# dmenu version
|
||||
VERSION = 1.7.1
|
||||
VERSION = 1.8
|
||||
|
||||
# Customize below to fit your system
|
||||
|
||||
@ -20,6 +20,11 @@ LDFLAGS = ${LIBS}
|
||||
#CFLAGS = -g -Wall -O2 ${INCS} -DVERSION=\"${VERSION}\"
|
||||
#LDFLAGS = -g ${LIBS}
|
||||
|
||||
# Solaris
|
||||
#CFLAGS = -fast ${INCS} -DVERSION=\"${VERSION}\"
|
||||
#LDFLAGS = ${LIBS}
|
||||
#CFLAGS += -xtarget=ultra
|
||||
|
||||
# compiler and linker
|
||||
CC = cc
|
||||
LD = ${CC}
|
||||
|
35
dmenu.1
35
dmenu.1
@ -3,12 +3,13 @@
|
||||
dmenu \- dynamic menu
|
||||
.SH SYNOPSIS
|
||||
.B dmenu
|
||||
.RB [ \-font " <name>"]
|
||||
.RB [ \-normbg " <color>"]
|
||||
.RB [ \-normfg " <color>"]
|
||||
.RB [ \-selbg " <color>"]
|
||||
.RB [ \-selfg " <color>"]
|
||||
.RB [ \-b ]
|
||||
.RB [ \-fn " <font>"]
|
||||
.RB [ \-nb " <color>"]
|
||||
.RB [ \-nf " <color>"]
|
||||
.RB [ \-p " <prompt>"]
|
||||
.RB [ \-sb " <color>"]
|
||||
.RB [ \-sf " <color>"]
|
||||
.RB [ \-t " <seconds>"]
|
||||
.RB [ \-v ]
|
||||
.SH DESCRIPTION
|
||||
@ -19,24 +20,27 @@ It manages huge amounts (up to 10.000 and more) of user defined menu items
|
||||
efficiently.
|
||||
.SS Options
|
||||
.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.
|
||||
.TP
|
||||
.B \-normbg <color>
|
||||
.B \-nb <color>
|
||||
defines the normal background color (#RGB, #RRGGBB, and color names are supported).
|
||||
.TP
|
||||
.B \-normfg <color>
|
||||
.B \-nf <color>
|
||||
defines the normal foreground color (#RGB, #RRGGBB, and color names are supported).
|
||||
.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>
|
||||
defines a prompt to be displayed before the input area.
|
||||
.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>
|
||||
defines the seconds to wait for standard input, before exiting (default is 3).
|
||||
.TP
|
||||
@ -87,4 +91,5 @@ Remove enough characters from the input field to change its filtering effect.
|
||||
.B Control-u
|
||||
Remove all characters from the input field.
|
||||
.SH SEE ALSO
|
||||
.BR dwm (1)
|
||||
.BR dwm (1),
|
||||
.BR wmii (1) .
|
||||
|
50
main.c
50
main.c
@ -178,6 +178,29 @@ kpress(XKeyEvent * e) {
|
||||
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) {
|
||||
default:
|
||||
if(num && !iscntrl((int) buf[0])) {
|
||||
@ -307,6 +330,7 @@ DC dc = {0};
|
||||
|
||||
int
|
||||
main(int argc, char *argv[]) {
|
||||
Bool bottom = False;
|
||||
char *font = FONT;
|
||||
char *maxname;
|
||||
char *normbg = NORMBGCOLOR;
|
||||
@ -324,24 +348,27 @@ main(int argc, char *argv[]) {
|
||||
timeout.tv_sec = 3;
|
||||
/* command line args */
|
||||
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];
|
||||
}
|
||||
else if(!strncmp(argv[i], "-normbg", 8)) {
|
||||
else if(!strncmp(argv[i], "-nb", 4)) {
|
||||
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];
|
||||
}
|
||||
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)) {
|
||||
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)) {
|
||||
if(++i < argc) timeout.tv_sec = atoi(argv[i]);
|
||||
}
|
||||
@ -350,7 +377,8 @@ main(int argc, char *argv[]) {
|
||||
exit(EXIT_SUCCESS);
|
||||
}
|
||||
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, "");
|
||||
dpy = XOpenDisplay(0);
|
||||
if(!dpy)
|
||||
@ -384,6 +412,8 @@ main(int argc, char *argv[]) {
|
||||
mx = my = 0;
|
||||
mw = DisplayWidth(dpy, screen);
|
||||
mh = dc.font.height + 2;
|
||||
if(bottom)
|
||||
my += DisplayHeight(dpy, screen) - mh;
|
||||
win = XCreateWindow(dpy, root, mx, my, mw, mh, 0,
|
||||
DefaultDepth(dpy, screen), CopyFromParent,
|
||||
DefaultVisual(dpy, screen),
|
||||
|
Reference in New Issue
Block a user