Blame SOURCES/cracklib-2.9.6-lookup.patch

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