]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
2005-01-16 GOTO Masanori <gotom@debian.or.jp>
authorRoland McGrath <roland@gnu.org>
Wed, 16 Feb 2005 10:43:02 +0000 (10:43 +0000)
committerRoland McGrath <roland@gnu.org>
Wed, 16 Feb 2005 10:43:02 +0000 (10:43 +0000)
[BZ #734]
* sysdeps/unix/rewinddir.c: Reset filepos.
* dirent/tst-seekdir.c: Check telldir value after calling rewinddir.

dirent/tst-seekdir.c
sysdeps/unix/rewinddir.c

index b833c30705fc06864956c2c75c7355dc0afbf3f4..43808fecb58a48d41bae0464293cae0a677e8c1b 100644 (file)
@@ -11,8 +11,23 @@ main (int argc, char *argv[])
   int i = 0;
   int result = 0;
   struct dirent *dp;
+  long int save0;
+  long int rewind;
 
   dirp = opendir (".");
+  if (dirp == NULL)
+    {
+      printf ("opendir failed: %m\n");
+      return 1;
+    }
+
+  save0 = telldir (dirp);
+  if (save0 == -1)
+    {
+      printf ("telldir failed: %m\n");
+      result = 1;
+    }
+
   for (dp = readdir (dirp); dp != NULL; dp = readdir (dirp))
     {
       /* save position 3 (after fourth entry) */
@@ -44,6 +59,19 @@ main (int argc, char *argv[])
   for (dp = readdir (dirp); dp != NULL; dp = readdir (dirp))
     printf ("%s\n", dp->d_name);
 
+  /* Check rewinddir */
+  rewinddir (dirp);
+  rewind = telldir (dirp);
+  if (rewind == -1)
+    {
+      printf ("telldir failed: %m\n");
+      result = 1;
+    }
+  else if (save0 != rewind)
+    {
+      printf ("rewinddir didn't reset directory stream\n");
+      result = 1;
+    }
 
   closedir (dirp);
   return result;
index 9f3724fc6af61c712a26436377e980210ae502a3..cb0f52079aeaeff2c00f76ad6549d256caafd34f 100644 (file)
@@ -30,6 +30,7 @@ rewinddir (dirp)
 {
   __libc_lock_lock (dirp->lock);
   (void) __lseek (dirp->fd, (off_t) 0, SEEK_SET);
+  dirp->filepos = 0;
   dirp->offset = 0;
   dirp->size = 0;
   __libc_lock_unlock (dirp->lock);