[BZ #6007]
authorUlrich Drepper <drepper@redhat.com>
Mon, 31 Mar 2008 18:30:26 +0000 (18:30 +0000)
committerUlrich Drepper <drepper@redhat.com>
Mon, 31 Mar 2008 18:30:26 +0000 (18:30 +0000)
2008-03-31  Ulrich Drepper  <drepper@redhat.com>
[BZ #6007]
* string/strfry.c: Handle empty strings again.

ChangeLog
string/strfry.c

index 52f4456..2cf9f3c 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2008-03-31  Ulrich Drepper  <drepper@redhat.com>
+
+       [BZ #6007]
+       * string/strfry.c: Handle empty strings again.
+
 2008-03-30  Ulrich Drepper  <drepper@redhat.com>
 
        [BZ #5443]
index d392d55..d3fcb14 100644 (file)
@@ -26,7 +26,6 @@ strfry (char *string)
 {
   static int init;
   static struct random_data rdata;
-  size_t len, i;
 
   if (!init)
     {
@@ -37,17 +36,18 @@ strfry (char *string)
       init = 1;
     }
 
-  len = strlen (string) - 1;
-  for (i = 0; i < len; ++i)
-    {
-      int32_t j;
-      __random_r (&rdata, &j);
-      j = j % (len - i) + i;
-
-      char c = string[i];
-      string[i] = string[j];
-      string[j] = c;
-    }
+  size_t len = strlen (string);
+  if (len > 0)
+    for (size_t i = 0; i < len - 1; ++i)
+      {
+       int32_t j;
+       __random_r (&rdata, &j);
+       j = j % (len - i) + i;
+
+       char c = string[i];
+       string[i] = string[j];
+       string[j] = c;
+      }
 
   return string;
 }