about summary refs log tree commit diff
diff options
context:
space:
mode:
authoranselm@anselm1 <unknown>2008-03-12 21:37:43 +0000
committeranselm@anselm1 <unknown>2008-03-12 21:37:43 +0000
commit38b866ba3453e2a7567b084a353e50a36ed92221 (patch)
tree6bb12f58a285958e90e0504c58d2c50b3d5d2869
parentremoved ido-matching, changed behavior of -i meaning case insensitive matchin... (diff)
downloaddmenu-38b866ba3453e2a7567b084a353e50a36ed92221.tar.gz
dmenu-38b866ba3453e2a7567b084a353e50a36ed92221.tar.bz2
dmenu-38b866ba3453e2a7567b084a353e50a36ed92221.zip
applied Sanders patch
-rw-r--r--LICENSE2
-rw-r--r--dmenu.c14
2 files changed, 7 insertions, 9 deletions
diff --git a/LICENSE b/LICENSE
index 2039f2a..8e87c0f 100644
--- a/LICENSE
+++ b/LICENSE
@@ -1,7 +1,7 @@
 MIT/X Consortium License
 
 © 2006-2008 Anselm R. Garbe <garbeam at gmail dot com>
-© 2006-2007 Sander van Dijk <a dot h dot vandijk at gmail dot com>
+© 2006-2008 Sander van Dijk <a dot h dot vandijk at gmail dot com>
 © 2006-2007 Michał Janeczek <janeczek at gmail dot com>
 
 Permission is hereby granted, free of charge, to any person obtaining a
diff --git a/dmenu.c b/dmenu.c
index 864c8f0..ddde475 100644
--- a/dmenu.c
+++ b/dmenu.c
@@ -37,7 +37,6 @@ struct Item {
 	Item *next;		/* traverses all items */
 	Item *left, *right;	/* traverses items matching current search pattern */
 	char *text;
-	Bool matched;
 };
 
 /* forward declarations */
@@ -89,6 +88,7 @@ Item *next = NULL;
 Item *prev = NULL;
 Item *curr = NULL;
 Window root, win;
+int (*fstrncmp)(const char *, const char *, size_t n) = strncmp;
 char *(*fstrstr)(const char *, const char *) = strstr;
 
 Item *
@@ -97,7 +97,6 @@ appenditem(Item *i, Item *last) {
 		item = i;
 	else
 		last->right = i;
-	i->matched = True;
 	i->left = last;
 	i->right = NULL;
 	last = i;
@@ -505,13 +504,10 @@ match(char *pattern) {
 	plen = strlen(pattern);
 	item = j = NULL;
 	nitem = 0;
-	for(i = allitems; i; i=i->next)
-		i->matched = False;
 	for(i = allitems; i; i = i->next)
-		if(!i->matched && !strncasecmp(pattern, i->text, plen))
+		if(!fstrncmp(pattern, i->text, plen))
 			j = appenditem(i, j);
-	for(i = allitems; i; i = i->next)
-		if(!i->matched && fstrstr(i->text, pattern))
+		else if(fstrstr(i->text, pattern))
 			j = appenditem(i, j);
 	curr = prev = next = sel = item;
 	calcoffsets();
@@ -662,8 +658,10 @@ main(int argc, char *argv[]) {
 
 	/* command line args */
 	for(i = 1; i < argc; i++)
-		if(!strcmp(argv[i], "-i"))
+		if(!strcmp(argv[i], "-i")) {
+			fstrncmp = strncasecmp;
 			fstrstr = cistrstr;
+		}
 		else if(!strcmp(argv[i], "-fn")) {
 			if(++i < argc) font = argv[i];
 		}