master
Connor Lane Smith 14 years ago
parent be9afce035
commit 86468aafe5
  1. 36
      dmenu.c

@ -55,8 +55,8 @@ static Atom utf8;
static Bool topbar = True;
static DC *dc;
static Item *items = NULL;
static Item *matches, *sel;
static Item *prev, *curr, *next;
static Item *matches, *matchend;
static Item *prev, *curr, *next, *sel;
static Window root, win;
static int (*fstrncmp)(const char *, const char *, size_t) = strncmp;
@ -308,12 +308,15 @@ keypress(XKeyEvent *ev) {
cursor = len;
break;
}
while(next) {
sel = curr = next;
if(next) {
curr = matchend;
calcoffsets();
curr = prev;
calcoffsets();
while(next && (curr = curr->right))
calcoffsets();
}
while(sel && sel->right)
sel = sel->right;
sel = matchend;
break;
case XK_Escape:
exit(EXIT_FAILURE);
@ -381,10 +384,10 @@ keypress(XKeyEvent *ev) {
void
match(void) {
size_t len;
Item *item, *itemend, *lexact, *lprefix, *lsubstr, *exactend, *prefixend, *substrend;
Item *item, *lexact, *lprefix, *lsubstr, *exactend, *prefixend, *substrend;
len = strlen(text);
matches = lexact = lprefix = lsubstr = itemend = exactend = prefixend = substrend = NULL;
matches = lexact = lprefix = lsubstr = matchend = exactend = prefixend = substrend = NULL;
for(item = items; item && item->text; item++)
if(!fstrncmp(text, item->text, len + 1))
appenditem(item, &lexact, &exactend);
@ -395,24 +398,25 @@ match(void) {
if(lexact) {
matches = lexact;
itemend = exactend;
matchend = exactend;
}
if(lprefix) {
if(itemend) {
itemend->right = lprefix;
lprefix->left = itemend;
if(matchend) {
matchend->right = lprefix;
lprefix->left = matchend;
}
else
matches = lprefix;
itemend = prefixend;
matchend = prefixend;
}
if(lsubstr) {
if(itemend) {
itemend->right = lsubstr;
lsubstr->left = itemend;
if(matchend) {
matchend->right = lsubstr;
lsubstr->left = matchend;
}
else
matches = lsubstr;
matchend = substrend;
}
curr = sel = matches;
calcoffsets();

Loading…
Cancel
Save