Compare commits
3 Commits
Author | SHA1 | Date | |
---|---|---|---|
d57c873f10 | |||
724f72142f | |||
5b8dce15d3 |
1
.hgtags
1
.hgtags
@ -26,3 +26,4 @@ b6e09682c8adcb6569656bee73c311f9ab457715 2.3
|
|||||||
03e83e2788c83ddd63b45a667939d7ec783c98cb 2.4.1
|
03e83e2788c83ddd63b45a667939d7ec783c98cb 2.4.1
|
||||||
1ca5d430524e838c52ede912533cb90108c5cd66 2.4.2
|
1ca5d430524e838c52ede912533cb90108c5cd66 2.4.2
|
||||||
041143e9fc544c62edc58af52cae9ac5237e5945 2.5
|
041143e9fc544c62edc58af52cae9ac5237e5945 2.5
|
||||||
|
775f761a5647a05038e091d1c99fc35d3034cd68 2.6
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
# dmenu version
|
# dmenu version
|
||||||
VERSION = 2.6
|
VERSION = 2.7
|
||||||
|
|
||||||
# Customize below to fit your system
|
# Customize below to fit your system
|
||||||
|
|
||||||
|
15
draw.c
15
draw.c
@ -12,7 +12,6 @@ drawtext(const char *text, unsigned long col[ColLast]) {
|
|||||||
int x, y, w, h;
|
int x, y, w, h;
|
||||||
static char buf[256];
|
static char buf[256];
|
||||||
unsigned int len, olen;
|
unsigned int len, olen;
|
||||||
XGCValues gcv;
|
|
||||||
XRectangle r = { dc.x, dc.y, dc.w, dc.h };
|
XRectangle r = { dc.x, dc.y, dc.w, dc.h };
|
||||||
|
|
||||||
XSetForeground(dpy, dc.gc, col[ColBG]);
|
XSetForeground(dpy, dc.gc, col[ColBG]);
|
||||||
@ -41,18 +40,12 @@ drawtext(const char *text, unsigned long col[ColLast]) {
|
|||||||
}
|
}
|
||||||
if(w > dc.w)
|
if(w > dc.w)
|
||||||
return; /* too long */
|
return; /* too long */
|
||||||
gcv.foreground = col[ColFG];
|
XSetForeground(dpy, dc.gc, col[ColFG]);
|
||||||
if(dc.font.set) {
|
if(dc.font.set)
|
||||||
XChangeGC(dpy, dc.gc, GCForeground, &gcv);
|
XmbDrawString(dpy, dc.drawable, dc.font.set, dc.gc, x, y, buf, len);
|
||||||
XmbDrawString(dpy, dc.drawable, dc.font.set, dc.gc,
|
else
|
||||||
x, y, buf, len);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
gcv.font = dc.font.xfont->fid;
|
|
||||||
XChangeGC(dpy, dc.gc, GCForeground | GCFont, &gcv);
|
|
||||||
XDrawString(dpy, dc.drawable, dc.gc, x, y, buf, len);
|
XDrawString(dpy, dc.drawable, dc.gc, x, y, buf, len);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
unsigned int
|
unsigned int
|
||||||
textw(const char *text) {
|
textw(const char *text) {
|
||||||
|
43
main.c
43
main.c
@ -110,7 +110,7 @@ drawmenu(void) {
|
|||||||
|
|
||||||
static void
|
static void
|
||||||
grabkeyboard(void) {
|
grabkeyboard(void) {
|
||||||
while(XGrabKeyboard(dpy, root, True, GrabModeAsync,
|
while(XGrabKeyboard(dpy, win, True, GrabModeAsync,
|
||||||
GrabModeAsync, CurrentTime) != GrabSuccess)
|
GrabModeAsync, CurrentTime) != GrabSuccess)
|
||||||
usleep(1000);
|
usleep(1000);
|
||||||
}
|
}
|
||||||
@ -454,24 +454,6 @@ main(int argc, char *argv[]) {
|
|||||||
eprint("dmenu: cannot open display\n");
|
eprint("dmenu: cannot open display\n");
|
||||||
screen = DefaultScreen(dpy);
|
screen = DefaultScreen(dpy);
|
||||||
root = RootWindow(dpy, screen);
|
root = RootWindow(dpy, screen);
|
||||||
if(isatty(STDIN_FILENO)) {
|
|
||||||
maxname = readstdin();
|
|
||||||
grabkeyboard();
|
|
||||||
}
|
|
||||||
else { /* prevent keypress loss */
|
|
||||||
grabkeyboard();
|
|
||||||
maxname = readstdin();
|
|
||||||
}
|
|
||||||
/* init modifier map */
|
|
||||||
modmap = XGetModifierMapping(dpy);
|
|
||||||
for (i = 0; i < 8; i++) {
|
|
||||||
for (j = 0; j < modmap->max_keypermod; j++) {
|
|
||||||
if(modmap->modifiermap[i * modmap->max_keypermod + j]
|
|
||||||
== XKeysymToKeycode(dpy, XK_Num_Lock))
|
|
||||||
numlockmask = (1 << i);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
XFreeModifiermap(modmap);
|
|
||||||
/* style */
|
/* style */
|
||||||
dc.norm[ColBG] = initcolor(normbg);
|
dc.norm[ColBG] = initcolor(normbg);
|
||||||
dc.norm[ColFG] = initcolor(normfg);
|
dc.norm[ColFG] = initcolor(normfg);
|
||||||
@ -493,6 +475,27 @@ main(int argc, char *argv[]) {
|
|||||||
dc.drawable = XCreatePixmap(dpy, root, mw, mh, DefaultDepth(dpy, screen));
|
dc.drawable = XCreatePixmap(dpy, root, mw, mh, DefaultDepth(dpy, screen));
|
||||||
dc.gc = XCreateGC(dpy, root, 0, 0);
|
dc.gc = XCreateGC(dpy, root, 0, 0);
|
||||||
XSetLineAttributes(dpy, dc.gc, 1, LineSolid, CapButt, JoinMiter);
|
XSetLineAttributes(dpy, dc.gc, 1, LineSolid, CapButt, JoinMiter);
|
||||||
|
if(!dc.font.set)
|
||||||
|
XSetFont(dpy, dc.gc, dc.font.xfont->fid);
|
||||||
|
drawmenu();
|
||||||
|
XMapRaised(dpy, win);
|
||||||
|
if(isatty(STDIN_FILENO)) {
|
||||||
|
maxname = readstdin();
|
||||||
|
grabkeyboard();
|
||||||
|
}
|
||||||
|
else { /* prevent keypress loss */
|
||||||
|
grabkeyboard();
|
||||||
|
maxname = readstdin();
|
||||||
|
}
|
||||||
|
/* init modifier map */
|
||||||
|
modmap = XGetModifierMapping(dpy);
|
||||||
|
for(i = 0; i < 8; i++)
|
||||||
|
for(j = 0; j < modmap->max_keypermod; j++) {
|
||||||
|
if(modmap->modifiermap[i * modmap->max_keypermod + j]
|
||||||
|
== XKeysymToKeycode(dpy, XK_Num_Lock))
|
||||||
|
numlockmask = (1 << i);
|
||||||
|
}
|
||||||
|
XFreeModifiermap(modmap);
|
||||||
if(maxname)
|
if(maxname)
|
||||||
cmdw = textw(maxname);
|
cmdw = textw(maxname);
|
||||||
if(cmdw > mw / 3)
|
if(cmdw > mw / 3)
|
||||||
@ -503,8 +506,6 @@ main(int argc, char *argv[]) {
|
|||||||
promptw = mw / 5;
|
promptw = mw / 5;
|
||||||
text[0] = 0;
|
text[0] = 0;
|
||||||
match(text);
|
match(text);
|
||||||
XMapRaised(dpy, win);
|
|
||||||
drawmenu();
|
|
||||||
XSync(dpy, False);
|
XSync(dpy, False);
|
||||||
|
|
||||||
/* main event loop */
|
/* main event loop */
|
||||||
|
Reference in New Issue
Block a user