X-Git-Url: https://git.subgeniuskitty.com/xmenu/.git/blobdiff_plain/006c94ce9c745acfb07758c0d71a008d6dd2abe6..112e23c3e8bd279b4ee5464f39fb2b8df48b7f6d:/xmenu.c?ds=inline diff --git a/xmenu.c b/xmenu.c index 2a8de09..c5290c9 100644 --- a/xmenu.c +++ b/xmenu.c @@ -233,7 +233,7 @@ error: errx(1, "improper position: %s", optarg); } -/* parse color string */ +/* parse font string */ static void parsefonts(const char *s) { @@ -1209,6 +1209,7 @@ run(struct Menu *currmenu) struct Menu *menu; struct Item *item; struct Item *previtem = NULL; + struct Item *lastitem; KeySym ksym; XEvent ev; @@ -1272,19 +1273,26 @@ selectitem: /* cycle through menu */ item = NULL; - if (ksym == XK_Home) { + if (ksym == XK_Home || ksym == KSYMFIRST) { item = itemcycle(currmenu, ITEMFIRST); - } else if (ksym == XK_End) { + } else if (ksym == XK_End || ksym == KSYMLAST) { item = itemcycle(currmenu, ITEMLAST); - } else if (ksym == XK_ISO_Left_Tab || ksym == XK_Up) { + } else if (ksym == XK_ISO_Left_Tab || ksym == XK_Up || ksym == KSYMUP) { item = itemcycle(currmenu, ITEMPREV); - } else if (ksym == XK_Tab || ksym == XK_Down) { + } else if (ksym == XK_Tab || ksym == XK_Down || ksym == KSYMDOWN) { item = itemcycle(currmenu, ITEMNEXT); - } else if ((ksym == XK_Return || ksym == XK_Right) && - currmenu->selected != NULL) { + } else if (ksym >= XK_1 && ksym <= XK_9){ + item = itemcycle(currmenu, ITEMFIRST); + lastitem = itemcycle(currmenu, ITEMLAST); + for (int i = ksym - XK_1; i > 0 && item != lastitem; i--) { + currmenu->selected = item; + item = itemcycle(currmenu, ITEMNEXT); + } + } else if ((ksym == XK_Return || ksym == XK_Right || ksym == KSYMRIGHT) && + currmenu->selected != NULL) { item = currmenu->selected; goto selectitem; - } else if ((ksym == XK_Escape || ksym == XK_Left) && + } else if ((ksym == XK_Escape || ksym == XK_Left || ksym == KSYMLEFT) && currmenu->parent != NULL) { item = currmenu->parent->selected; currmenu = currmenu->parent;