summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog7
-rw-r--r--io/bug-ftw3.c22
2 files changed, 26 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index 11536222c4..52cf6559cc 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,10 @@
+2001-12-17 Ulrich Drepper <drepper@redhat.com>
+
+ * io/ftw.c (ftw_dir): Handle inaccessibility of toplevel dir
+ different than implemented in last patch.
+ * io/bug-ftw3.c: Adjust test for changed handling of
+ inaccessibility of toplevel dir.
+
2001-12-16 Roland McGrath <roland@frob.com>
* nss/nsswitch.c (__nss_next): Don't use __FUNCTION__ as literal.
diff --git a/io/bug-ftw3.c b/io/bug-ftw3.c
index 98bb563f0c..e3f24d61e1 100644
--- a/io/bug-ftw3.c
+++ b/io/bug-ftw3.c
@@ -4,10 +4,13 @@
#include <stdlib.h>
#include <unistd.h>
+static int cb_called;
+
static int
cb (const char *fname, const struct stat *st, int flag)
{
printf ("%s %d\n", fname, flag);
+ cb_called = 1;
return 0;
}
@@ -15,7 +18,9 @@ int
main (void)
{
char tmp[] = "/tmp/ftwXXXXXX";
+ char tmp2[] = "/tmp/ftwXXXXXX/ftwXXXXXX";
char *dname;
+ char *dname2;
int r;
int e;
@@ -26,13 +31,23 @@ main (void)
exit (1);
}
- if (chmod (dname, S_IWUSR|S_IXUSR|S_IWGRP|S_IXGRP|S_IWOTH|S_IXOTH) != 0)
+ memcpy (tmp2, tmp, strlen (tmp));
+ dname2 = mkdtemp (tmp2);
+ if (dname2 == NULL)
+ {
+ printf ("mkdtemp: %m\n");
+ rmdir (dname);
+ exit (1);
+ }
+
+ if (chmod (dname, S_IWUSR|S_IWGRP|S_IWOTH) != 0)
{
printf ("chmod: %m\n");
+ rmdir (dname);
exit (1);
}
- r = ftw (dname, cb, 10);
+ r = ftw (dname2, cb, 10);
e = errno;
printf ("r = %d", r);
if (r != 0)
@@ -40,7 +55,8 @@ main (void)
puts ("");
chmod (dname, S_IRWXU|S_IRWXG|S_IRWXO);
+ rmdir (dname2);
rmdir (dname);
- return r != -1 && e == EACCES;
+ return (r != -1 && e == EACCES) || cb_called;
}