aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog12
-rw-r--r--dirent/tst-seekdir.c26
-rw-r--r--dlfcn/Makefile2
-rw-r--r--sysdeps/unix/seekdir.c5
4 files changed, 33 insertions, 12 deletions
diff --git a/ChangeLog b/ChangeLog
index 008531d40f..3217df8161 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,15 @@
+2001-08-07 Jakub Jelinek <jakub@redhat.com>
+
+ * sysdeps/unix/seekdir.c (seekdir): Set dirp->filepos.
+
+ * dirent/tst-seekdir.c (main): Check whether telldir right after
+ seekdir returns 2nd argument given to seekdir.
+
+2001-08-07 Franz Sirl <Franz.Sirl-kernel@lauterbach.com>
+
+ * dlfcn/Makefile (tststatic-ENV): Add $(common-objpfx) to
+ LD_LIBRARY_PATH.
+
2001-08-07 Andreas Jaeger <aj@suse.de>
Andreas Schwab <schwab@suse.de>
Bruno Haible <haible@clisp.cons.org>
diff --git a/dirent/tst-seekdir.c b/dirent/tst-seekdir.c
index f4d99ae632..b833c30705 100644
--- a/dirent/tst-seekdir.c
+++ b/dirent/tst-seekdir.c
@@ -5,20 +5,21 @@
int
main (int argc, char *argv[])
{
-
DIR * dirp;
long int save3 = 0;
+ long int cur;
int i = 0;
+ int result = 0;
struct dirent *dp;
- dirp = opendir(".");
- for (dp = readdir(dirp); dp != NULL; dp = readdir(dirp))
+ dirp = opendir (".");
+ for (dp = readdir (dirp); dp != NULL; dp = readdir (dirp))
{
/* save position 3 (after fourth entry) */
if (i++ == 3)
- save3 = telldir(dirp);
+ save3 = telldir (dirp);
- printf("%s\n", dp->d_name);
+ printf ("%s\n", dp->d_name);
/* stop at 400 (just to make sure dirp->__offset and dirp->__size are
scrambled */
@@ -26,17 +27,24 @@ main (int argc, char *argv[])
break;
}
- printf("going back past 4-th entry...\n");
+ printf ("going back past 4-th entry...\n");
/* go back to saved entry */
seekdir (dirp, save3);
+ /* Check whether telldir equals to save3 now. */
+ cur = telldir (dirp);
+ if (cur != save3)
+ {
+ printf ("seekdir (d, %ld); telldir (d) == %ld\n", save3, cur);
+ result = 1;
+ }
/* print remaining files (3-last) */
- for (dp = readdir(dirp); dp != NULL; dp = readdir(dirp))
- printf("%s\n", dp->d_name);
+ for (dp = readdir (dirp); dp != NULL; dp = readdir (dirp))
+ printf ("%s\n", dp->d_name);
closedir (dirp);
- return 0;
+ return result;
}
diff --git a/dlfcn/Makefile b/dlfcn/Makefile
index e8d9ccb35d..46ba661f54 100644
--- a/dlfcn/Makefile
+++ b/dlfcn/Makefile
@@ -47,7 +47,7 @@ ifeq (yesyesyes,$(build-static)$(build-shared)$(elf))
tests += tststatic
tests-static += tststatic
modules-names += modstatic
-tststatic-ENV = LD_LIBRARY_PATH=$(objpfx)
+tststatic-ENV = LD_LIBRARY_PATH=$(objpfx):$(common-objpfx)
endif
extra-objs += $(modules-names:=.os) eval.os
diff --git a/sysdeps/unix/seekdir.c b/sysdeps/unix/seekdir.c
index dc1716ada7..1790e6237b 100644
--- a/sysdeps/unix/seekdir.c
+++ b/sysdeps/unix/seekdir.c
@@ -1,4 +1,4 @@
-/* Copyright (C) 1991, 1995, 1996, 1997, 1999 Free Software Foundation, Inc.
+/* Copyright (C) 1991,1995,1996,1997,1999,2001 Free Software Foundation, Inc.
This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or
@@ -30,8 +30,9 @@ seekdir (dirp, pos)
long int pos;
{
__libc_lock_lock (dirp->lock);
- (void) __lseek(dirp->fd, pos, SEEK_SET);
+ (void) __lseek (dirp->fd, pos, SEEK_SET);
dirp->size = 0;
dirp->offset = 0;
+ dirp->filepos = pos;
__libc_lock_unlock (dirp->lock);
}