c5a710
diff -up cracklib-2.9.6/lib/packlib.c.lookup cracklib-2.9.6/lib/packlib.c
c5a710
--- cracklib-2.9.6/lib/packlib.c.lookup	2018-10-10 14:19:06.988958835 +0200
c5a710
+++ cracklib-2.9.6/lib/packlib.c	2018-11-26 16:04:34.648256614 +0100
c5a710
@@ -585,12 +585,11 @@ fprintf(stderr, "look for (%s)\n", strin
c5a710
     fprintf(stderr, "---- %lu, %lu ----\n", lwm, hwm);
c5a710
 #endif
c5a710
 
c5a710
-    middle = lwm + ((hwm - lwm + 1) / 2);
c5a710
-
c5a710
     for (;;)
c5a710
     {
c5a710
 	int cmp;
c5a710
 
c5a710
+	middle = lwm + ((hwm - lwm + 1) / 2);
c5a710
 
c5a710
 #if DEBUG
c5a710
 	fprintf(stderr, "lwm = %lu,  middle = %lu,  hwm = %lu\n", lwm, middle, hwm);
c5a710
@@ -617,24 +616,28 @@ fprintf(stderr, "look for (%s)\n", strin
c5a710
 	    return(middle);
c5a710
         }
c5a710
 
c5a710
-        if (middle == hwm)
c5a710
-        {
c5a710
-#if DEBUG
c5a710
-		fprintf(stderr, "at terminal subdivision, stopping search\n");
c5a710
-#endif
c5a710
-		break;
c5a710
-        }
c5a710
-
c5a710
 	if (cmp < 0)
c5a710
 	{
c5a710
-	    hwm = middle;
c5a710
-	    middle = lwm + ((hwm - lwm ) / 2);
c5a710
-	}
c5a710
+	    if (middle == lwm)
c5a710
+	    {
c5a710
+#if DEBUG 
c5a710
+		fprintf(stderr, "at terminal subdivision from right, stopping search\n");
c5a710
+#endif
c5a710
+		break;
c5a710
+	    }
c5a710
+	    hwm = middle - 1;
c5a710
+	} 
c5a710
 	else if (cmp > 0)
c5a710
 	{
c5a710
-	    lwm = middle;
c5a710
-	    middle = lwm + ((hwm - lwm + 1) / 2);
c5a710
-	}
c5a710
+	    if (middle == hwm)
c5a710
+	    {
c5a710
+#if DEBUG 
c5a710
+		fprintf(stderr, "at terminal subdivision from left, stopping search\n");
c5a710
+#endif
c5a710
+		break;
c5a710
+	    }
c5a710
+	    lwm = middle + 1;
c5a710
+	} 
c5a710
     }
c5a710
 
c5a710
     return (PW_WORDS(pwp));