Xinqi Bao's Git
projects
/
dmenu.git
/ blobdiff
summary
|
log
|
commit
|
diff
|
tree
raw
|
inline
| side by side
fixed
[dmenu.git]
/
main.c
diff --git
a/main.c
b/main.c
index
14581c4
..
2f20efb
100644
(file)
--- a/
main.c
+++ b/
main.c
@@
-29,7
+29,7
@@
static int mx, my, mw, mh;
static int ret = 0;
static int nitem = 0;
static unsigned int cmdw = 0;
static int ret = 0;
static int nitem = 0;
static unsigned int cmdw = 0;
-static Bool
done = Fals
e;
+static Bool
running = Tru
e;
static Item *allitems = NULL; /* first of all items */
static Item *item = NULL; /* first of pattern matching items */
static Item *sel = NULL;
static Item *allitems = NULL; /* first of all items */
static Item *item = NULL; /* first of pattern matching items */
static Item *sel = NULL;
@@
-77,17
+77,17
@@
drawmenu()
dc.y = 0;
dc.w = mw;
dc.h = mh;
dc.y = 0;
dc.w = mw;
dc.h = mh;
- drawtext(NULL, False);
+ drawtext(NULL, False
, False
);
/* print command */
if(cmdw && item)
dc.w = cmdw;
/* print command */
if(cmdw && item)
dc.w = cmdw;
- drawtext(text[0] ? text : NULL, False);
+ drawtext(text[0] ? text : NULL, False
, False
);
dc.x += cmdw;
if(curr) {
dc.w = SPACE;
dc.x += cmdw;
if(curr) {
dc.w = SPACE;
- drawtext((curr && curr->left) ? "<" : NULL, False);
+ drawtext((curr && curr->left) ? "<" : NULL, False
, False
);
dc.x += dc.w;
/* determine maximum items */
dc.x += dc.w;
/* determine maximum items */
@@
-95,13
+95,13
@@
drawmenu()
dc.w = textw(i->text);
if(dc.w > mw / 3)
dc.w = mw / 3;
dc.w = textw(i->text);
if(dc.w > mw / 3)
dc.w = mw / 3;
- drawtext(i->text, sel == i);
+ drawtext(i->text, sel == i
, sel == i
);
dc.x += dc.w;
}
dc.x = mw - SPACE;
dc.w = SPACE;
dc.x += dc.w;
}
dc.x = mw - SPACE;
dc.w = SPACE;
- drawtext(next ? ">" : NULL, False);
+ drawtext(next ? ">" : NULL, False
, False
);
}
XCopyArea(dpy, dc.drawable, win, dc.gc, 0, 0, mw, mh, 0, 0);
XFlush(dpy);
}
XCopyArea(dpy, dc.drawable, win, dc.gc, 0, 0, mw, mh, 0, 0);
XFlush(dpy);
@@
-219,11
+219,11
@@
kpress(XKeyEvent * e)
else if(text)
fprintf(stdout, "%s", text);
fflush(stdout);
else if(text)
fprintf(stdout, "%s", text);
fflush(stdout);
-
done = Tru
e;
+
running = Fals
e;
break;
case XK_Escape:
ret = 1;
break;
case XK_Escape:
ret = 1;
-
done = Tru
e;
+
running = Fals
e;
break;
case XK_BackSpace:
if((i = len)) {
break;
case XK_BackSpace:
if((i = len)) {
@@
-290,6
+290,7
@@
int
main(int argc, char *argv[])
{
char *maxname;
main(int argc, char *argv[])
{
char *maxname;
+ Item *i;
XEvent ev;
XSetWindowAttributes wa;
XEvent ev;
XSetWindowAttributes wa;
@@
-316,6
+317,7
@@
main(int argc, char *argv[])
/* style */
dc.bg = getcolor(BGCOLOR);
dc.fg = getcolor(FGCOLOR);
/* style */
dc.bg = getcolor(BGCOLOR);
dc.fg = getcolor(FGCOLOR);
+ dc.border = getcolor(BORDERCOLOR);
setfont(FONT);
wa.override_redirect = 1;
setfont(FONT);
wa.override_redirect = 1;
@@
-348,7
+350,7
@@
main(int argc, char *argv[])
XSync(dpy, False);
/* main event loop */
XSync(dpy, False);
/* main event loop */
- while(
!done
&& !XNextEvent(dpy, &ev)) {
+ while(
running
&& !XNextEvent(dpy, &ev)) {
switch (ev.type) {
case KeyPress:
kpress(&ev.xkey);
switch (ev.type) {
case KeyPress:
kpress(&ev.xkey);
@@
-363,6
+365,16
@@
main(int argc, char *argv[])
}
XUngrabKeyboard(dpy, CurrentTime);
}
XUngrabKeyboard(dpy, CurrentTime);
+ while(allitems) {
+ i = allitems->next;
+ free(allitems->text);
+ free(allitems);
+ allitems = i;
+ }
+ if(dc.font.set)
+ XFreeFontSet(dpy, dc.font.set);
+ else
+ XFreeFont(dpy, dc.font.xfont);
XFreePixmap(dpy, dc.drawable);
XFreeGC(dpy, dc.gc);
XDestroyWindow(dpy, win);
XFreePixmap(dpy, dc.drawable);
XFreeGC(dpy, dc.gc);
XDestroyWindow(dpy, win);